S V M B I O S 


SYM53C875 

PCI-SCSI I/O 
Processor with 

UltraSCSI 





DATA MANUAL 
REVISION 2.0 





The product described in this publication is a product of Symbios Logic Inc. 


SCRIPTS is a trademark and TolerANT is a registered trademark of Symbios Logic 
Inc. 


UltraSCSI is the term used by the SCSI Trade Association to describe Fast-20 SCSI, 
as documented in the SCSI-3 Fast-20 Parallel Interface standard, X3.277-199X. 


It is the policy of Symbios Logic to improve products as new technology, 
components, software, and firmware become available. Symbios Logic, therefore, 
reserves the right to change specifications without notice. 


The products in this manual are not intended for use in life-support appliances, 
devices, or systems. Use of these products in such applications without the written 
consent of the appropriate Symbios Logic officer is prohibited 

Copyright ©1995, 1996 
By Symbios Logic Inc. 

All Rights Reserved 
Printed in U.S.A. 


We use comments from our readers to improve Symbios product literature. Please 
e-mail any comments regarding technical documentation to pubs@symbios.com. 



Preface 


Preface 

This manual assumes some prior knowledge of current and proposed SCSI and PCI standards. For back¬ 
ground information, please contact: 

ANSI 

11 West 42nd Street 
New York, NY 10036 
(212) 642-4900 

Ask for document number X3.131-1994 (SCSI-2) 

Global Engineering Documents 

15 Inverness Way East 
Englewood, CO 80112 

(800) 854-7179 or (303) 792-2181 (outside US.) 

Ask for document number X3.131-1994 (SCSI-2) or X3.253 (SCSI-3 Parallel Interface) 

ENDL Publications 

14426 Black Walnut Court 
Saratoga, CA 95070 
(408) 867-6642 

Document names: SCSI Bench Reference, SCSI Encyclopedia 

Prentice HaU 

Englewood Cliffs, NJ 07632 
(201) 767-5937 

Ask for document number ISBN 0-13-796855-8, SCSI: Understanding the Small Computer System Interface 

Symbios Logic Electronic Bulletin Board 

(719) 573-3562 

SCSI Electronic Bulletin Board 

(719) 574-0424 

Symbios Logic Internet Anonymous FTP Site 

ftp.symbios.com (204.131.200.1) 

Directory: /pub/ncrchips/scsi 

Symbios Logic World Wide Web Home Page 

http://www.symbios.com 

PCI Special Interest Group 

P.O. Box 10470 
Portland, OR 97214 

(800) 433-5177; (503) 797-4201 (International); FAX (503) 234-6762 

Symbios Logic PCI-SCSI Programming Guide 


SYM53C875 Data Manual 


i 



Revision Record 


Revision Record 


Page No. 

Date 

Remarks 

n/a 

6/95 

Rev 1.0 

1-2, 1-4, 1-5, 2-3, 2- 
12, 2-13,2-14, 2-17, 

3- 3, 3-7,3-12, 3-13, 

4- 15, 5-10, 5-11,5- 
15, 5-16, 5-21,5- 
23,5-35, 5-38, 5-48, 

5- 49, 5-51,6-6,7-2, 
7-4, 7-9,7-32, 7-33, 
7-34 

3/96 

Rev 2.0 

Fast-20 changed to UltraSCSI throughout, except for name of 
Fast-20 Enable bit; added SCSI clock doubler 


II 


SYM53C875 Data Manual 






Contents 


Preface ... o»o ... o. ..o oo .... o..,. o .0 o , o., o . ooo i 

Revision Record ............. ........................................ ...... ......... ii 

List of Figures . xiii 

List of Tables .. xv 

Chapter 1 
Introduction 

What is Covered in This Manual ..... 1-1 

General Description ........1-1 

Package and Feature Options .. 1-2 

Benefits of UltraSCSI .. 1-2 

TolerANT Technology .. 1-3 

SYM53C875 Benefits Summary. 1-3 

SCSI Performance .. 1-3 

PCI Performance.1-4 

Integration .. 1-4 

Ease of Use .. 1-4 

Flexibility .. 1-5 

Reliability ..1-5 

Testability .. 1-5 

Chapter 2 

Functional Description 

SCSI Core.2-1 

DMA Core ..2-1 

SCRIPTS Processor. 2-1 

Internal SCRIPTS RAM... 2-2 

SDMS: The Total SCSI Solution. 2-2 

Designing an UltraSCSI System .. 2-2 

Using the SCSI Clock Doubler... 2-3 

Prefetching SCRIPTS Instructions .. 2-3 

Op Code Fetch Burst Capability ..2-4 

External Memory Interface.2-4 

PCI Cache Mode.2-5 

Load/Store Instructions .2-5 

3.3 Volt/5 Volt PCI Interface .2-5 

Additional Access to General Purpose Pins.2-5 


SYM53C875 Data Manual 














































Contents 


JTAG Boundary Scan Testing .. . . » o . . « , . « . . „ . . « , . . .. 2-6 

Big and Little Endian Support .............. ... o.. ... .... ... ..... .... .... ........... . 2-6 

Loopback Mode.... 2-7 

Parity Options.... ................ ... 2-7 

DMA FIFO ........................ 2-10 

Data Paths.. ............................ ... 2-11 

Asynchronous SCSI Send .. 2-11 

Synchronous SCSI Send ...... 2-11 

Asynchronous SCSI Receive. 2-12 

Synchronous SCSI Receive .. 2-12 

SCSI Bus Interface. 2-13 

Differential Mode.. . 2-13 

8-bit/l 6-bit SCSI and the Differential Interface .2-14 

Terminator Networks .2-16 

(Re)Select During (Re)Selection.2-18 

Synchronous Operation .... ... . 2-18 

Determining the Data Transfer Rate.... 2-18 

SCNTL3 Register, bits 6-4 (SCF2-0) ....2-19 

SCNTL3 Register, bits 2-0 (CCF2-0) .. 2-19 

SXFER Register, bits 7-5 (TP2-0). 2-19 

Achieving Optimal SCSI Send Rates . 2-19 

UltraSCSI Synchronous Data Transfers .. 2-19 

Interrupt Handling .. 2-21 

Polling and Hardware Interrupts.. .. 2-21 

Registers ..2-21 

ISTAT. 2-21 

SISTO and SISTl ..2-21 

DSTAT.2-21 

SIENO and SIENl .. 2-21 

DIEN. 2-22 

DCNTL.2-22 

Fatal vs. Non-Fatal Interrupts .. 2-22 

Masking .. 2-22 

Stacked Interrupts . 2-23 

Halting in an Orderly Fashion. 2-23 

Sample Interrupt Service Routine .. 2-24 

Chained Block Moves .. 2-24 

Wide SCSI Send Bit . 2-24 

Wide SCSI Receive Bit.2-25 

SWIDE Register.2-25 

SODL Register.2-25 

Chained Block Move SCRIPTS Instruction.2-25 


IV 


SYM53C875 Data Manual 




























































Contents 


Chapter 3 

PCI Functional Description 

PCI Addressing .... ..... 3-1 


PCI Bus Commands and Functions Supported 

PCI Cache Mode.... 

Support for PCI Cache Line Size Register 

Selection of Cache Line Size.. 

Alignment.. 

Memory Move Misalignment. 

Memory Write and Invalidate Command . 

Multiple Cache line Transfers . 

Latency. 

PCI Target Retry. 

PCI Target Disconnect.. 

Memory Read Line Command ......... 

Memory Read Multiple Command ..... 

Burst Size Selection .............. 

Read Multiple with Read Line Enabled 
Unsupported PCI Commands. 

Configuration Registers .. 

Register OOh 
Vendor ID 

Read Only ..... 

Register 02h 
Device ID 

Read Only. 

Register 04h 
Command 

Read/Write . 

Register 06h 
Status 

Read/Write . 

Register 08h 
Revision ID 

Read Only . ... , 

Register 09h 
Class Code 

Read Only.. 

Register OCh 
Cache Line Size 

Read/Write ... 

Register ODh 
Latency Timer 

Read/Write . 

Register OEh 
Header Type 

Read Only.. 


3-1 

3-3 

3-3 

3-3 

3-3 

3-4 

3-4 

3-4 

3-5 

3-5 

3-5 

3-5 

3-6 

3-6 

3-6 

3-6 

3-7 


3-8 


. 3-8 

. 3-8 

3-10 

3-11 

3-11 

3-11 

3-12 

3-12 


SYM53C875 Data Manual 


V 











































Contents 


Register lOh 
Base Address Zero (I/O) 

Read/Write...3-12 

Register 14h 

Base Address One (Memory) 

Read/Write...3-12 

Register 18h 
RAM Base Address 

Read/Write.3-12 

Register 2C-2F 
Subsystem Data 

Read/Write.3-12 

Register 3 Oh 

Expansion ROM Base Address 

Read/Write.3-12 

Register 34-3 5h 
General Purpose Pin Control 

Read/Write.3-13 

Register 3Ch 
Interrupt Line 

Read/Write.3-13 

Register 3Dh 
Interrupt Pin 

Readonly . 3-13 

Register 3Eh 
Min_Gnt 

Readonly .3-13 

Register 3Fh 
Max_Lat 

Readonly .3-13 

Chapter 4 

Signal Descriptions 

53C875, 53C875J Power and Ground Pins.4-5 

53C875N Power and Ground Pins.4-6 

53C875JB Power and Ground Pins.4-6 

System Pins.4-8 

Address and Data Pins.4-9 

Interface Control Pins.4-11 

Arbitration Pins.4-12 

Error Reporting Pins.4-12 

SCSI Pins.4-13 

Additional Interface Pins.4-15 

External Memory Interface Pins.4-17 

JTAG Pins.4-18 


VI 


SYi\/l53C875 Data Manual 

























Contents 


Chapter 5 

Operating Registers 

Register 00 (80) 

SCSI Control Zero (SCNTLO) 

Read/Write .. o ..... o ... ..... ........ . 5-5 

Register 01 (81) 

SCSI Control One (SCNTLl) 

Read/Write .. 5-7 

Register 02 (82) 

SCSI Control Two (SCNTL2) 

Read/Write .... . 5-9 

Register 03 (83) 

SCSI Control Three (SCNTL3) 

Read/Write .. 5-10 

Register 04 (84) 

SCSI Chip ID (SCID) 

Read/Write . 5-12 

Register 05 (85) 

SCSI Transfer (SXFER) 

Read/Write . 5-12 

Register 06 (86) 

SCSI Destination ID (SDID) 

Read/Write . 5-14 

Register 07 (87) 

General Purpose (GPREG) 

Read/Write .5-15 

SDMS Use of GPIO Pins .5-15 

Register 08 (88) 

SCSI First Byte Received (SFBR) 

Read/Write . 5-16 

Register 09 (89) 

SCSI Output Control Latch (SOCL) 

Read /Write . .. 5-16 

Register OA (09) 

SCSI Selector ID (SSID) 

Readonly.5-17 

Register OB (8B) 

SCSI Bus Control lines (SBCL) 

Read Only.5-17 

Register OC (8C) 

DMA Status (DSTAT) 

Read Only. 5-18 

Register OD (8D) 

SCSI Status Zero (SSTATO) 

Read Only .. 5-19 

Register OE (8E) 

SCSI Status One (SSTATl) 

Read Only.5-20 


SYM53C875 Data Manual vii 

























Contents 


Register OF (8F) 

SCSI Status Two (SSTAT2) 

(Read Only). 

Registers 10-13 (90-93) 

Data Structure Address (DSA) 
Read/Write .................. .0 . 

Register 14 (94) 

Interrupt Status (ISTAT) 

(Read/Write) .. . . . 

Register 18 (98) 

Chip Test Zero (CTESTO) 

Read/Write .. 

Register 19 (99) 

Chip Test One (CTESTl) 

Read Only . 

Register lA (9A) 

Chip Test Two (CTEST2) 

Read/Write.. 

Register IB (9B) 

Chip Test Three (CTEST3) 

Read/Write... 

Registers IC-IF (9C-9F) 

Temporary (TEMP) 

Read/Write. 

Register 20 (AO) 

DMA FIFO (DFIFO) 

ReadAJ^rite.. 

Register 21 (Al) 

Chip Test Four (CTEST4) 

Read/Write. 

Register 22 (A2) 

Chip Test Five (CTEST5) 

Read/Write.. 

Register 23 (A3) 

Chip Test Six (CTEST6) 

Read/Write. 

Registers 24-26 (A4-A6) 

DMA Byte Counter (DBC) 

Read/Write. 

Register 27 (A7) 

DMA Command (DCMD) 

Read/Write .. 

Registers 28-2B (A8-AB) 

DMA Next Address (DNAD) 

Read/Write. 

Registers 2C-2F (AC-AF) 

DMA SCRIPTS Pointer (DSP) 

Read/Write. 

Registers 30-33 (B0-B3) 

DMA SCRIPTS Pointer Save (DSPS) 
Read/Write. 


.5-21 

.5-22 

.5-23 

.5-25 

.5-25 

.5-26 

.5-27 

.5-28 

.5-28 

.5-29 

.5-30 

.5-31 

.5-32 

.5-32 

.5-33 

.5-33 

.5-34 


viii 


SYM53C875 Data Manual 



























Contents 


Registers 34-37 (B4-B7) 

Scratch Register A (SCRATCH A) 

Read/Write . . . , . . . ... ....... 5-34 

Register 38 (B8) 

DMA Mode (DMODE) 

ReadA)7rite ...... 5-35 

Register 39 (B9) 

DMA Interrupt Enable (DIEN) 

Read/Write .5-36 

Register 3A (BA) 

Scratch Byte Register (SBR) 

Read/Write . 5-37 

Register 3B (BB) 

DMA Control (DCNTL) 

Read/Write .5-38 

Register 3 C-3F (BC-BF) 

Adder Sum Output (ADDER) 

Read Only . .. 5-39 

Register 40 (CO) 

SCSI Interrupt Enable Zero (SIENO) 

Read/Write .5-39 

Register 41 (Cl) 

SCSI Interrupt Enable One (SIENl) 

Read/Write . 5-40 

Register 42 (C2) 

SCSI Interrupt Status Zero (SISTO) 

Read Only .. 5-41 

Register 43 (C3) 

SCSI Interrupt Status One (SISTl) 

Read Only.5-42 

Register 44 (C4) 

SCSI Longitudinal Parity (SLPAR) 

Read/Write .5-43 

Register 45 (C5) 

SCSI Wide Residue (SWIDE) 

Read/Write .5-44 

Register 46 (C 6) 

Memory Access Control (MACNTL) 

Read/Write .5-44 

Register 47 (C7) 

General Purpose Pin Control (GPCNTL) 

Read/Write ..5-45 

Register 48 (C8) 

SCSI Timer Zero (STIMEO) 

Read /Write. 5-45 

Register 49 (C9) 

SCSI Timer One (STIMEl) 

Read/Write ..5-46 

Register 4A (CA) 

Response ID Zero (RESPIDO) 

Read/Write .5-48 

SYM53C875 Data Manual ix 






















Contents 


Register 4B (CB) 

Response ID One(RESPIDl) 

Read/Write.. .o o.. o. o oo ... o o » 5-48 

Register 4C (CC) 

SCSI Test Zero (STESTO) 

Read Only ... ............................. . 5-48 

Register 4D (CD) 

SCSI Test One (STESTl) 

Read/Write. 5-49 

Doubling the SCSI CLK Frequency .. 5-50 

Register 4E (CE) 

SCSI Test Two (STEST2) 

ReadAJ7rite .. 5-50 

Register 4F (CF) 

SCSI Test Three (STEST3) 

ReadAJ^rite .. 5-51 

Register 50-51 (DO-Dl) 

SCSI Input Data Latch (SIDL) 

Read Only .... ..... 5-53 

Registers 54-55 (D4-D5) 

SCSI Output Data Latch (SODL) 

Read/Write.. ... ... ......... ......5-53 

Registers 58-59 (D8-D9) 

SCSI Bus Data Lines (SBDL) 

Read Only . 5-54 

Registers 5C-5F (DC-DF) 

Scratch Register B (SCRATCHB) 

(ReadA)7rite) .. 5-54 

Registers 60h-7Fh (EOh-FFh) 

Scratch Registers C-J 
(SCRATCHC-SCRATCHJ) 

Read/Write .. 5-55 


Chapter 6 

Instruction Set of the I/O Processor 

SCSI SCRIPTS .........6-1 

Sample Operation. 6-2 

Block Move Instructions.....6-4 

First Dword.6-4 

Second Dword.6-7 

I/O Instructions .6-8 

First Dword.6-8 

Second Dword.6-12 

Read/Write Instructions .6-13 

First Dword.6-13 

Second Dword.6-14 

Read-Modify-Write Cycles . 6-14 

Move to/from SFBR Cycles .6-14 


X 


SYM53C875 Data Manual 

































Contents 


Transfer Control Instructions o. .o ...... .00 .................... ..o .o. o , 6-16 

First Dword ..........6-16 

Second Dword.......... . 6-20 

Memory Move Instructions ...... 6-20 

Read/Write System Memory from a Script ......6-21 

Second Dword........ . 6-21 

Third Dword ..... 6-21 

Load and Store Instructions. 6-23 

First Dword.. ...... ... 6-23 

Second Dword.6-24 


Chapter? 

Electrical Characteristics 

DC Characteristics. 7-1 

TolerANT Technology Electrical Characteristics ......7-6 

AC Characteristics........ 7-9 

PCI and External Memory Interface Timing Diagrams ........7-11 

Timing diagrams included in this section . ..... 7-11 

Target Cycles . 7-11 

Initiator Cycles .... ....7-11 

External Memory Cycles. 7-11 

PCI and External Memory Interface Timings ...7-34 

SCSI Timings .. 7-36 


Appendix A 

Register Summary 

Appendix B 

Mechanical Drawings 

Appendix C 

External Memory Interface Diagram Examples 

Index.Index-1 


SYM53C875 Data Manual 


xi 

































Contents 


xii 


SYM53C875 Data Manual 



List of Figures 


List of Figures 

Figure 1-1: SYM53C875 External Memory Interface . 1-6 

Figure 1-2: SYM53C875 Chip Block Diagram . .. 1-6 

Figure 2-1: DMA FIFO Sections .. 2-10 

Figure 2-2: SYM53C875 Host Interface Data Paths .. 2-12 

Figure 2-3: SYM53C875 Differential Wiring Diagram .. 2-15 

Figure 2-4: Regulated Termination. 2-17 

Figure 2-5: Determining the Synchronous Transfer Rate . 2-20 

Figure 2-6: Block Move and Chained Block Move Instructions .2-26 

Figure 3-1: PCI Configuration Register Map .3-7 

Figure 3-2: Command Register Layout . .. 3-9 

Figure 3-3: Status Register Layout . 3-11 

Figure 4-1: SYM53C875 Pin Diagram .. 4-1 

Figure 4-2: SYM53C875J Pin Diagram .4-2 

Figure 4-3: SYM53C875N Pin Diagram .4-3 

Figure 4-4: SYM53C875JB Pin Diagram (Top View) .4-4 

Figure 4-5: SYM53C875 Functional Signal Grouping .4-7 

Figure 5-1: SYM53C875 Register Address Map .5-4 

Figure 6-1: SCRIPTS Overview .6-3 

Figure 6-2: Block Move Instruction Register.6-5 

Figure 6-3: I/O Instruction Register .6-9 

Figure 6-4: Read/Write Instruction Register . 6-13 

Figure 6-5: Transfer Control Instruction.6-17 

Figure 6-6: Memory Move Instructions .6-22 

Figure 6-7: Load and Store Instruction Format.6-24 

Figure 7-1: Rise and Fall Time Test Conditions .7-7 

Figure 7-2: SCSI Input Filtering.7-7 

Figure 7-3: Hysteresis of SCSI Receiver .7-8 

Figure 7-4: Input Current as a Function of Input Voltage .7-8 

Figure 7-5: Output Current as a Function of Output Voltage .7-8 

Figure 7-6: Clock Timing .7-9 

Figure 7-7: Reset Input.7-10 

SYM53C875 Data Manual xiii 





































List of Figures 


Figure 7-8: Interrupt Output ...7-10 

Figure 7-9: PCI Configuration Register Read .................................... 7-12 

Figure 7-10: PCI Configuration Register Write . .. 7-13 

Figure 7-11: Operating Register/SCRIPTS RAM read . 7-14 

Figure 7-12: Operating Register/SCRIPTS RAM write ............................. 7-15 

Figure 7-13: External Memory Read . 7-16 

Figure 7-14: External Memory Write . 7-17 

Figure 7-15: Op Code Fetch, non-burst .. 7-18 

Figure 7-16: Burst Op Code Fetch .. 7-19 

Figure 7-17: Back to Bac k Read .. 7-20 

Figure 7-18: Back to Back Write .... ... . 7-21 

Figure 7-19: Burst Read...... 7-22 

Figure 7-20: Burst Write .... 7-23 

Figure 7-21: Read Cycle, Normal/Fast Memory (>64 KB), single-byte access .7-24 

Figure 7-22: Write Cycle, Normal/Fast Memory (>64 KB), single-b54:e access .7-25 

Figure 7-23: Read Cycle, Normal/Fast Memory (>128 KB ), multiple-byte access .7-26 

Figure 7-24: Write Cycle, Normal/Fast Memory (>128 KB), multiple-byte access .7-27 

Figure 7-25: Read Cycle, Slow Memory (>64 KB) . 7-28 

Figure 7-26: Write Cycle, Slow Memory (>64 KB) ............................... 7-29 

Figure 7-27: Read Cycle, Normal/Fast Memory (< 64K) 7-30 

Figure 7-28: Write Cycle, Normal/Fast Memory (< 64 K) .7-31 

Figure 7-29: Read Cycle, Slow Memory (< 64K) 7-32 

Figure 7-30: Write Cycle, Slow Memory (<64K) 7-33 

Figure 7-31: Initiator Asynchronous Send . 7-36 

Figure 7-32: Initiator As 5 mchronous Receive ..7-36 

Figure 7-33: Target As 5 mchronous Send . 7-37 

Figure 7-34: Target As 5 mchronous Receive . .. 7-37 

Figure 7-35: Initiator and Target Synchronous Transfers . 7-38 

Figure B-1: SYM53C875, SYM 53C875J Mechanical Drawing .B-1 

Figure B-2: SYM53C875N Mechanical Drawing . ..B-2 

Figure B-3: SYM53C875JB (169-pin BGA) Mechanical Drawing .B-3 

Figure C-1: 16 K Interface With 200 ns Memory .C-1 

Figure C-2: 64 K Interface with 150 ns Memory .C-2 

Figure C-3: 256 K Interface With 150 ns Memory .C-3 

Figure C-4: 512 K Interface With 150 ns Memory .C-4 


XIV 


SYM53C875 Data Manual 








































List of Tables 


List ofTables 


Table 2-1: External Memory Support. 2-4 

Table 2-2: Bits Used for Parity Control and Generation .. 2-8 

Table 2-3: SCSI Parity Control. 2-9 

Table 2-4: SCSI Parity Errors and Interrupts.2-9 

Table 3-1: PCI Bus Commands and Encoding Types.3-2 

Table 4-1: 53C875, 53C875JPower and Ground Pins. 4-5 

Table 4-2: 53C875N Power and Ground Pins .. 4-6 

Table 4-3: 53C875JB Power and Ground Pins ..... . 4-6 

Table 4-4: System Pins... 4-8 

Table 4-5: Address and Data Pins. ..... 4-9 

Table 4-6: Interface Control Pins...4-11 

Table 4-7: Arbitration Pins...4-12 

Table 4-8: Error Reporting Pins.4-12 

Table 4-9: SCSI Pins...4-13 

Table 4-10: Additional Interface Pins ....4-15 

Table 4-11: External Memory Interface Pins ..4-17 

Table 4-12: JTAG Pins (53C875J/53C875N/53C875JB Only) ........................ 4-18 

Table 5-1: Operating Register Addresses and Descriptions ..5-1 

Table 5-2: Examples of Synchronous Transfer Periods for SCSI-1 Transfer Rates.5-13 

Table 5-3: Example Transfer periods for fast SCSI-2 and Fast-20 transfer rates.5-13 

Table 6-1: Read/Write Instructions. .. 6-15 

Table 7-1: Absolute Maximum Stress Ratings.7-1 

Table 7-2: Operating Conditions.7-1 

Table 7-3: SCSI Signals - SD(15-0)/, SDP(l-O)/, SREQ/SACK/.7-2 

Table 7-4: SCSI Signals - SMSG, SI_0/, SC_D/, SATN/, SBSY/, SSEL/, SRST/.7-2 

Table 7-5: Input Signals - CLK, SCLK, GNT/, IDSEL, RST/, TESTIN, DIFFSENS, 

BIG_UT/.7-2 

Table 7-6: Capacitance.7-3 

Table 7-7: Output Signal - MAC/_TESTOUT, REQ/.7-3 

Table 7-8: Output Signals - IRQ/, SDIR(15-0), SDIRPO, SDIRPl, BSYDIR, SELDIR, 

RSTDIR, TGS, IGS, 


MAS/(l-0), MCE/, MOE/, MWE/... .7-3 


SYM53C875 Data Manual 


XV 

































List of Tables 


Table 7-9: Output Signal - SERR/ ... 7-3 

Table 7-10: Bidirectional Signals - AD(31-0), C_BE/(3-0), FRAME/, IRDY/, TRDY/, 

DEVSEIV, STOP/, PERR/, PAR, BYTEPAR3-0 (53C875N only). ............ 7-4 

Table 7-11: Bidirectional Signals - GPIOO_FETCB[/, GPI01_MASTER/, GPI02_MAS2/, 

GPI03, GPI04.... 7-4 

Table 7-12: Bidirectional Signals - MAD(7-0) .. 7-5 

Table 7-13: Input Signals —TDI, TMS, TCK (53C875J,53C875JB, 53C875N only).7-5 

Table 7-14: Output Signal — TDO (53C875, 53C875JB, 53C875N only).7-5 

Table 7-15: TolerANT Technology Electrical Characteristics...7-6 

Table 7-16: SYM53C875 PCI and External Memory Interface Timings ..7-34 

Table 7-17: SCSI-1 transfers (Single-Ended, 5.0 MB/s).. 7-38 

Table 7-18: SCSI-1 Transfers (Differential, 4.17 MB/s). .. 7-39 

Table 7-19: SCSI-2 Fast Transfers (10.0 MB/s (8-bit transfers) or 

20.0 MB/s (16-bit transfers), 40 MHz clock) ....... 7-39 

Table 7-20: SCSI-2 Fast Transfers (10.0 MB/s (8-bit transfers) or 

20.0 MB/s (16-bit transfers), 50 MHz clock) ..7-40 

Table 7-21: UltraSCSI Single-Ended Transfers (20.0 MB/s (8-bit transfers) or 

40.0 MB/s (16-bit transfers), 80 MHz clock).7-40 

Table 7-22: UltraSCSI Differential Transfers (20.0 MB/s (8-bit transfers) or 

40.0 MB/s (16-bit transfers), 80 MHz clock).7-41 


XVI 


SYM53C875 Data Manual 














Introduction 

What is Covered in This Manuai 


Chapter 1 

Introduction 


What is Covered in This 
Manual 

This manual provides reference information on the 
SYM53C875 PCI-SCSI I/O Processor. It is 
intended for system designers and programmers 
who are using this device to design a SCSI port for 
PCI-based personal computers, workstations, or 
embedded applications. 

This chapter includes general information about 
the SYM53C875 and other members of the 
SYM53C8XX family of PCI-SCSI I/O Processors. 
Chapter 2 describes the main functional areas of 
the chip in more detail, including the interfaces to 
the SCSI bus. Chapter 3 describes the chip’s con¬ 
nection to the PCI bus, including the PCI com¬ 
mands and configuration registers supported. 
Chapter 4 contains the pin diagrams and defini¬ 
tions of each signal. Chapter 5 describes each bit 
in the operating registers, organized by address. 
Chapter 6 defines all of the SCSI SCRIPTS 
instructions that are supported by the 
SYM53C875. Chapter 7 contains the electrical 
characteristics and AC timings for the chip. The 
appendixes contain a register summary, a mechan¬ 
ical drawing of the SYM53C875, and several 
example interface drawings to connect the 
SYM53C875 to an external ROM. 

This data manual assumes the user is familiar with 
the current and proposed standards for SCSI and 
PCI. For additional background information on 
these topics, please refer to the list of reference 
materials provided in the Preface of this docu¬ 
ment. 


General Description 

The SYM53C875 PCI-SCSI I/O Processor brings 
high-performance I/O solutions to host adapter, 
workstation, and general computer designs, mak¬ 
ing it easy to add SCSI to any PCI system. It pro¬ 
vides a local memory bus for local storage of the 
device’s BIOS ROM in flash memory or standard 
EPROMs. Most versions of the SYM53C875 also 
support Big and Little Endian byte addressing to 
accommodate a variety of data configurations. The 
SYM53C875 supports programming of local 
FLASH memory for updates to BIOS or 
SCRIPTS programs. 

The SYM53C875 is a pin-for-pin replacement for 
the SYM53C825 PCI-SCSI I/O processor, with 
added support for the SCSI-3 UltraSCSI standard 
as well as other new features. Some software 
enhancements are needed to take advantage of the 
new features and UltraSCSI transfer rates sup¬ 
ported by the SYM53C875.The SYM53C875 
performs UltraSCSI transfers or fast 8- or 16- bit 
SCSI transfers in single-ended or differential 
mode, and improves performance by optimizing 
PCI bus utilization. A system diagram showing the 
connections of the SYM53C875 with an external 
ROM or flash memory is pictured in Figure 1-1. A 
block diagram of the SYM53C875 is pictured in 
Figure 1-2. 

The SYM53C875 integrates a high-performance 
SCSI core, a PCI bus master DMA core, and the 
S 3 mibios Logic SCSI SCRIPTS^m processor to 
meet the flexibility requirements of SCSI-3 and 
UltraSCSI standards. It is designed to implement 
multi-threaded JJO algorithms with a minim u m of 
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processor intervention, solving the protocol over¬ 
head problems of previous intelligent and non- 
intelligent adapter designs. 

The SYM53C875 is fully supported by the 
Symbios SCSI Device Management System 
(SDMS^’'^, a software package that supports the 
Advanced SCSI Protocol Interface (ASPI) and the 
ANSI Common Access Method (CAM). SDMS 
provides BIOS and driver support for hard disk, 
tape, removable media products, and CD-ROM 
under the major PC operating systems. 

Package and Feature 
Options 

The SYM53C875 is available in three versions 
with different packaging and feature options. The 
SYM53C875 is packaged in a 160-pin plastic quad 
flat pack. The SYM53C875J is identical to the 
SYM53C875 with additional pins that support 
JTAG boundary scan testing. The JTAG boundary 
scan signals replace the TESTIN, MAC/ 
_TESTOUT, BIG_UT/, and SDIRPl pins. The 
SYM53C875N includes all of the signals in the 
SYM53C875, with the additions of the JTAG pins 
and four additional signals for extended parity 
checking and generation. The SYM53C875JB is 
identical to the SYM53C875J, but is packaged in a 
169-pin ball grid array. 


Benefits of UltraSCSI 

UltraSCSI is an extension of the SCSI-3 standard 
that expands the bandwidth of the SCSI bus and 
allows faster s 3 mchronous SCSI transfer rates. 
When enabled, UltraSCSI performs 20 megatrans¬ 
fers during an I/O operation, which results in 
approximately doubling the sjmchronous transfer 
rates of fast SCSI-2. The SYM53C875 can per¬ 
form 8-bit, UltraSCSI synchronous transfers as 
fast as 20 MB/s.This advantage is most noticeable 
in heavily loaded systems, or large-block size appli¬ 
cations such as video on-demand and image pro¬ 
cessing. 

One advantage of UltraSCSI is that it significantly 
improves SCSI bandwidth while preserving exist¬ 
ing hardware and software investments. The 
SYM53C875 is compatible with all existing 
SYM53C825 and SYM53C825A software; the 
only changes required are to enable the chip to 
perform synchronous negotiations for UltraSCSI 
rates. The SYM53C875 can use the same board 
socket as an SYM53C825, with the addition of an 
80MHz SCLK or enabling the internal SCSI clock 
doubler to provide the correct frequency when 
transferring synchronous SCSI data at 50 nanosec¬ 
ond transfer rates. Some changes to existing 
cabling or system designs may be needed to main¬ 
tain signal integrity at UltraSCSI synchronous 
transfer rates. These design issues are discussed in 
Chapter 2. 
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TolerANT Technology 

The SYM53C875 features TolerANT® technol¬ 
ogy, which includes active negation on the SCSI 
drivers and input signal filtering on the SCSI 
receivers. Active negation causes the SCSI 
Request, Acknowledge, Data, and Parity signals to 
be actively driven high rather than passively pulled 
up by terminators. Active negation is enabled by 
setting bit 7 in the STEST3 register. 

TolerANT receiver technology improves data 
integrity in unreliable cabling environments, where 
other devices would be subject to data corruption. 
TolerANT receivers filter the SCSI bus signals to 
eliminate unwanted transitions, without the long 
signal delay associated with RC-t 5 ^e input filters. 
This improved driver and receiver technology 
helps eliminate double clocking of data, the single 
biggest reliability issue with SCSI operations. 
TolerANT input signal filtering is a built in feature 
of the SYM53C875 and all Symbios Logic fast 
SCSI devices. On the SYM53C875, the user may 
select a filtering period of 30 or 60 ns, with bit 1 in 
the STEST2 register. 

The benefits ofTolerANT include increased 
immunity to noise when the signal is going high, 
better performance due to balanced duty cycles, 
and improved fast SCSI transfer rates. In addition, 
TolerANT SCSI devices do not cause glitches on 
the SCSI bus at power up or power down, so other 
devices on the bus are also protected fi:om data 
corruption. TolerANT is compatible with both the 
Alternative One and Alternative Two termination 
schemes proposed by the American National Stan¬ 
dards Institute. 


SYM53C875 Benefits 
Summary 


SCSI Performance 

■ Includes 4KB internal RAM for SCRIPTS 
instruction storage 

■ Performs wide, UltraSCSI synchronous 
transfers as fast as 40 MB/s 

■ SCSI synchronous offset increased from 8 to 
16 levels 

■ Supports variable block size and scatter/gather 
data transfers. 

■ Performs sustained memory-to-memory 
DMA transfers faster than 47 MB/s (@ 33 
MHz)) 

■ M in im iz es SCSI I/O start latency 

■ Performs complex bus sequences without 
interrupts, including restore data pointers 

■ Reduces ISR overhead through a unique 
interrupt status reporting method 

■ Performs fast and wide SCSI bus transfers in 
single-ended and differential mode 

■ 10 MB/s asynchronous (20 MB/s with 

UltraSCSI) 

■ 20 MB/s synchronous (40 MB/s with 
UltraSCSI) 

■ Load and Store SCRIPTS instruction 
increases performance of data transfers to and 
from chip registers 

■ Supports target disconnect and later reconnect 
with no interrupt to the system processor 

■ Supports multi-threaded I/O algorithms in 
SCSI SCRIPTS with fast I/O context 
switching 

■ Expanded Register Move instruction supports 
additional arithmetic capability 
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PCI Performance 

■ Complies with PCI 2.1 specification 

■ Bursts 2,4,8,16,32, 64, or 128 dwords across 
PCI bus 

■ Supports 32-bit word data bursts with variable 
burst lengths. 

■ Pre-fetches up to 8 dwords of SCRIPTS 
instructions 

■ Bursts SCRIPTS op code fetches across the 
PCI bus 

■ Performs zero wait-state bus master data bursts 
faster than 110 MB/s (@ 33 MHz) 

■ Supports PCI Cache Line Size register 

■ Supports PCI Write and Invalidate, Read Line, 
and Read Multiple commands 

Integration 

■ 3.3V/5V PCI interface 

■ Full 32-bit PCI DMA bus master 

■ Can be used as a third-party PCI bus DMA 
controller by using Memory to Memory Move 
instructions 

■ High performance SCSI core 

■ Integrated SCRIPTS processor 


Ease of Use 

■ Up to one megabyte of add-in memory 
support for BIOS and SCRIPTS storage 

■ Direct PCI-to-SCSI connection 

■ Reduced SCSI development effort 

■ Easily adapted to the Advanced SCSI Protocol 
Interface (ASPI) or the ANSI Common Access 
Method (CAM), with SDMS software. 

■ Compiler-compatible with existing 
SYM53C7XX and SYM53C8XX family 
SCRIPTS 

■ Direct connection to PCI, and SCSI single- 
ended and differential buses 

■ Development tools and sample SCSI 
SCRIPTS available 

■ Maskable and pollable interrupts 

■ Wide SCSI, A or P cable, and up to 16 devices 
supported 

■ Three programmable SCSI timers: Select/ 
Reselect, Handshake-to-Handshake, and 
General Purpose. The time-out period is 
programmable firom 100 |as to greater than 
25.6 seconds 

■ SDMS software for complete PC-based 
operating system support 

■ Support for relative jumps 

■ SCSI Selected As ID bits for responding with 
multiple IDs 
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Flexibility 

■ High level programming interface (SCSI 
SCRIPTS) 

■ Programs local memory bus FLASH memory 

■ Big/Little Endian support 

■ Selectable 88- or 536-byte DMA FIFO for 
backward compatibility 

■ Tailored SCSI sequences execute from main 
system RAM or internal SCRIPTS RAM 

■ Flexible programming interface to tune I/O 
performance or to adapt to unique SCSI 
devices 

■ Support for changes in the logical I/O interface 
definition 

■ Low level access to all registers and all SCSI 
bus signals 

■ Fetch, Master, and Memory Access control 
pins 

■ Separate SCSI and system clocks 

■ SCSI clock doubler bits enable UltraSCSI 
transfer rates with a 40 MHz SCSI clock 

■ Selectable IRQ pin disable bit 

■ 32 additional scratch pad registers 

■ Ability to route system clock to SCSI clock 

Reliability 

■ 2 KV ESD protection on SCSI signals 

■ Typical 300 mV SCSI bus hysteresis 

■ Protection against bus reflections due to 
impedance mismatches 

■ Controlled bus assertion times (reduces RFI, 
improves reliability, and eases FCC 
certification) 


■ Latch-up protection greater than 150 mA 

■ Voltage feed through protection (minimum 
leakage current through SCSI pads) 

■ 25% of pins are power and ground 

■ Power and ground isolation of FO pads and 
internal chip logic 

■ TolerANT technology provides: 

■ Active negation of SCSI Data, Parity, 
Request, and Acknowledge signals for 
improved fast SCSI transfer rates. 

■ Input signal filtering on SCSI receivers 
improves data integrity, even in noisy 
cabling environments. 

■ JTAG Boundary scan support (SYM, 
53C875J, 53C875JB, 53C875N only) 

■ Extended PCI parity checking and generation 
(SYM53C875N only) 

■ Extended SCSI parity checking 

Testability 

■ All SCSI signals accessible through 
programmed FO 

■ SCSI loopback diagnostics 

■ SCSI bus signal continuity checking 

■ Support for single-step mode operation 

■ Test mode (AND tree) to check pin continuity 
to the board (most package options) 

■ JTAG Boundary scan support (SYM, 
53C875J, 53C875JB, 53C875N only) 
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Chapter 2 

Functional Description 


The SYM53C875 is composed of three functional 
blocks: the SCSI Core, the DMA Core, and the 
SCRIPTS Processor.The SYM53C875 is fully 
supported by the SCSI Device Management Sys¬ 
tem (SDMS), a complete software package that 
supports the Symbios Logic product line of SCSI 
processors and controllers. 


SCSI Core 

The SCSI core supports the 8- or 16-bit data bus. 
It supports UltraSCSI synchronous transfer rates 
up to 40 MB/s, SCSI synchronous transfer rates 
up to 20 MB/s, and asynchronous transfer rates up 
to 10 MB/s on a 16-bit wide SCSI bus. The SCSI 
core can be programmed with SCSI SCRIPTS, 
making it easy to “fine tune” the system for specific 
mass storage devices or SCSI-3 requirements. 

The SCSI core offers low-level register access or a 
high-level control interface. Like first generation 
SCSI devices, the SYM53C875 SCSI core can be 
accessed as a register-oriented device. The ability 
to sample and/or assert any signal on the SCSI bus 
can be used in error recovery and diagnostic proce¬ 
dures. In support of loopback diagnostics, the 
SCSI core may perform a self-selection and oper¬ 
ate as both an initiator and a target. 

The SYM53C875 SCSI core is controlled by the 
integrated SCRIPTS processor through a high- 
level logical interface. Commands controlling the 
SCSI core are fetched out of the main host mem¬ 
ory or local memory. These commands instruct the 
SCSI core to Select, Reselect, Disconnect, Wait for 
a Disconnect, Transfer Information, Change Bus 
Phases and, in general, implement all aspects of 
the SCSI protocol. The SCRIPTS processor is a 
special high-speed processor optimized for SCSI 
protocol. 


DMA Core 

The DMA core is a bus master DMA device that 
attaches directly to the industry standard PCI Bus. 
The DMA core is tighdy coupled to the SCSI core 
through the SCRIPTS processor, which supports 
uninterrupted scatter/gather memory operations. 

The SYM53C875 supports 32-bit memory and 
automatically supports misaligned DMA transfers. 
A 536-b5?te FIFO allows the SYM53C875 to sup¬ 
port 2,4, 8, 16, 32, 64, or 128 longword bursts 
across the PCI bus interface. 


SCRIPTS Processor 

The SCSI SCRIPTS processor allows both DMA 
and SCSI commands to be fetched from host 
memory or internal SCRIPTS RAM. Algorithms 
written in SCSI SCRIPTS control the actions of 
the SCSI and DMA cores and are executed firom 
32-bit system RAM. The SCRIPTS processor exe¬ 
cutes complex SCSI bus sequences independently 
of the host CPU. 

The SCRIPTS processor can begin a SCSI I/O 
operation in approximately 500 ns. This compares 
with 2-8 ms required for traditional intelligent host 
adapters. Algorithms may be designed to tune 
SCSI bus performance, to adjust to new bus device 
types (such as scanners, communication gateways, 
etc.), or to incorporate changes in the SCSI-2 or 
SCSI-3 logical bus definitions without sacrificing 
I/O performance. SCSI SCRIPTS are hardware- 
independent, so they can be used interchangeably 
on any host or CPU system bus. 
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Internal 

SCRIPTS RAM 

The SYM53C875 has 4 KB (1024 x 32 bits) of 
internal, general purpose RAM. The RAM is 
designed for SCRIPTS program storage, but is not 
limited to this type of information. When the chip 
fetches SCRIPTS instructions or Table Indirect 
information from the internal RAM, these fetches 
remain internal to the chip and do not use the PCI 
bus. Other types of access to the RAM by the 
SYM53C875 use the PCI bus, as if they were 
external accesses. The MADS pin enables the 4K 
internal RAM. To disable the internal RAM, con¬ 
nect a 4.7K O resistor between the MADS pin and 

Vss- 

The RAM can be relocated by the PCI system 
BIOS anywhere in 32-bit address space.The RAM 
Base Address register in PCI configuration space 
contains the base address of the internal RAM. 
This register is similar to the ROM Base Address 
register in PCI configuration space. To simplify 
loading of SCRIPTS instructions, the base address 
of the RAM will appear in the SCRATCHB regis¬ 
ter when bit 3 of the CTEST2 register is set. The 
RAM is b 5 rte-accessible from the PCI bus and will 
be visible to any bus-mastering device on the bus. 
External accesses to the RAM (i.e., by the CPU) 
follow the same timing sequence as a standard 
slave register access, except that the target wait 
states required will drop from 5 to 3. 

A complete set of development tools is available for 
writing custom drivers with SCSI SCRIPTS. For 
more information on the SCSI SCRIPTS instruc¬ 
tions supported by the SYM53C875, see Chapter 
6 . 


SDMS: The Total SCSI 
Solution 

For users who do not need to develop custom driv- 
ersj Symbios Logic provides a total SCSI solution 
in PC environments with the SCSI Device Man¬ 
agement System (SDMS). SDMS provides BIOS 
driver support for hard disk, tape, and removable 
media peripherals for the major PC-based operat¬ 
ing systems. 

SDMS includes a SCSI BIOS to manage all SCSI 
functions related to the device. It also provides a 
series of SCSI device drivers that support most 
major operating systems. SDMS supports a multi¬ 
threaded I/O application programming interface 
(API) for user-developed SCSI applications. 
SDMS supports both the ASPI and CAM SCSI 
software specifications. 


Designing an UltraSCSI 
System 

Migrating an existing single-ended SCSI design 
from SCSI-2 to UltraSCSI requires minor soft¬ 
ware modifications as well as consideration for 
some hardware design guidelines. Since UltraSCSI 
is based on existing SCSI standards, it can use 
existing software programs as long as the software 
is able to negotiate for UltraSCSI synchronous 
transfer rates. 

In the area of hardware, the primary area of con¬ 
cern in single-ended systems is to maintain signal 
integrity at high data transfer rates. To assure reli¬ 
able operation at UltraSCSI transfer speeds, follow 
the system design parameters recommended in the 
SCSI-3 Fast-20 Parallel Interface standard, which 
is available from the SCSI BBS referenced at the 
beginning of this manual. Chapter 7 contains 
UltraSCSI timing information. In addition to the 
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guidelines in the draft standard, make the follow¬ 
ing software and hardware adjustments to accom¬ 
modate UltraSCSI transfers: 

■ Set the Fast-20 Enable bit to enable UltraSCSI 
transfers. 

■ Set the TolerANT Enable bit, bit 7 in the 
STEST3 register whenever the Fast-20 Enable 
bit is set. 

■ Do not extend the SREQ/SACK filtering 
period with STEST2 bit 1. 

■ Use an 80 MHz SCSI clock or enable the 
SCSI clock doubler using bits 2 and 3 of the 
STESTl register. Set the Halt SCSI clock 
(HSC) bit in STEST3 before switching to the 
doubled SCSI clock. 


Using the SCSI 
Clock Doubler 

The SYM53C875 can double the firequency of a 
40-50 MHz SCSI clock, allowing the system to 
perform UltraSCSI transfers in systems that do 
not have 80 MHz clock input. This option is user- 
selectable with bit settings in the STESTl, 
STEST3, and SCNTL3 registers. At power-on or 
reset, the doubler is disabled and powered down. 
Follow these steps to use the clock doubler: 

1. Set the SCLK Doubler Enable bit (STESTl, 
bit 3) 

2. Wait20|is 

3. Halt the SCSI clock by setting the Halt SCSI 
Clock bit (STEST3 bit 5) 

4. Set the clock conversion factor using the SCF 
and CCF fields in the SCNTL3 register 

5. Set the SCLK Doubler Select bit (STESTl, 
bit 2) 

6. Clear the Halt SCSI Clock bit 


Prefetching SCRIPTS 
Instructions 

When enabled (by setting the Prefetch Enable bit 
in the DCNTL register), the prefetch logic in the 
SYM53C875 fetches 8 dwords of instructions. The 
prefetch logic automatically determines the maxi¬ 
mum burst size that it can perform, based on the 
burst length as determined by the values in the 
DMODE register. If the unit cannot perform 
bursts of at least four dwords, it will disable itself. 
While the SYM53C875 is prefetching SCRIPTS 
instructions, the PCI Cache Line Size register 
value does not have any effect and the Read Line, 
Read Multiple, and Write and Invalidate com¬ 
mands will not be used. 

The SYM53C875 may flush the contents of the 
prefetch unit under certain conditions, listed 
below, to ensure that the chip always operates firom 
the most current version of the software. When one 
of these conditions apply, the contents of the 
prefetch unit are flushed automatically. 

1. On every Memory Move instruction. The 
Memory Move instruction is often used to 
place modified code directly into memory. To 
make sure that the chip executes all recent 
modifications, the prefetch unit flushes its 
contents and loads the modified code every 
time a instruction is issued. To avoid 
inadvertently flushing the prefetch unit 
contents, use the No Flush option for all 
Memory Move operations that do not modify 
code within the next 8 dwords. For more 
information on this instruction, refer to 
Chapter 6. 

2. On every Store instruction. The Store 
instruction may also be used to place modified 
code direcdy into memory. To avoid 
inadvertently flushing the prefetch unit 
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contents, use the No Flush option for all Store 
operations that do not modify code within the 
next 8 dwords. 

3. On every write to the DSP. 

4. On all Transfer Control instructions when the 
transfer conditions are met. This is necessary 
because the next instruction to be executed is 
not the sequential next instruction in the 
prefetch unit. 

5. When the Pre-Fetch Flush bit (DCNTL bit 6) 
is set. The unit flushes whenever this bit is set. 
The bit is self-clearing. 


Op Code Fetch 
Burst Capability 

Setting the Burst Op Code Fetch Enable bit in the 
DMODE register (38h) causes the SYM53C875 
to burst in the first two longwords of all instruction 
fetches. If the instruction is a memory-to-memory 
move, the third longword will be accessed in a sep¬ 
arate ownership. If the instruction is an indirect 
type, the additional longword will be accessed in a 
subsequent bus ownership. If the instruction is a 
table indirect Block Move, the SYM53C875 will 
use two accesses to obtain the four longwords 
required, in two bursts of two longwords each. 

Note: this feature is only useful if pre-fetching is 
disabled. 


External Memory Interface 

The SYM53C875 supports up to one megab 5 ^e of 
external memory in binary increments from 16 
KB, to allow the use of expansion ROM for add-in 
PCI cards. The device also supports flash ROM 
updates through the add-in interface and the 
GPI04 pin (used to control Vpp, the power supply 
for programming external memory).This interface 
is designed for low-speed operations such as down¬ 
loading instruction code from ROM; it is not 
intended for dynamic activities such as executing 
instructions. 


System requirements include the SYM53C875, 
two or three external 8-bit address holding regis¬ 
ters (HCT273 or HCT374), and the appropriate 
memory device. The 4.7 Kf2 pull-down resistors 
on the MAD bus require HC or HCT external 
components to be used. If in-system flash ROM 
updates are required, a 7406 (high voltage open 
collector inverter), an MTD4P05, and several pas¬ 
sive components are also needed. The memory size 
and speed is determined by pull-down resistors on 
the 8-bit bidirectional memory bus at power up. 
The SYM53C875 senses this bus shortly after the 
release of the Reset signal and configures the ROM 
Base Address register and the memory cycle state 
machines for the appropriate conditions. 

The external memory interface works with a vari¬ 
ety of ROM sizes and speeds. An example set of 
interface drawings is in Appendix C. 

The SYM53C875 supports a variety of sizes and 
speeds of expansion ROM, using pull-down resis¬ 
tors on the MAD(3-0) pins. The encoding of pins 
MAD(3-1) allows the user to define how much 
external memory is available to the SYM53C875. 
Table 2-1 shows the memory space associated with 
the possible values of MAD(3-l).The MAD(3-1) 
pins are fully defined in Chapter 4, “Signal 
Descriptions.” 


Table 2-1: External Memory Support 


MA0(3-1) 

Available Memory Space 

000 

16 KB 

001 

32 KB 

010 

64 KB 

oil 

128 KB 

100 

256 KB 

101 

512 KB 

no 

1024 KB 

111 

no external memory present 
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To use one of the configurations mentioned above 
in a host adapter board design, put 4.7 KQ pull- 
down resistors on the MAD pins corresponding to 
the available memory space. For example, to con¬ 
nect to a 32 KB external ROM, use pull-downs on 
AiAD(3) and MAD(2). If the external memory 
interface is not used, then no external resistors are 
necessary since there are internal pull-ups on the 
MAD bus. The internal pull-up resistors are dis¬ 
abled when external pull-down resistors are 
detected, to reduce current drain. 

The SYM53C875 allows the system to determine 
the size of the available external memory using the 
Expansion ROM Base Address register in PCI 
configuration space. For more information on how 
this works, refer to the PCI specification or the 
Expansion ROM Base Address register description 
in Chapter 3. 

MAD(O) is the slow ROM pin. When pulled down, 
it enables two extra clock cycles of data access time 
to allow use of slower memory devices. The exter¬ 
nal memory interface also supports updates to 
flash memory. The 12 volt power supply for flash 
memory, Vpp, is enabled and disabled with the 
GPI04 pin and the GPI04 control bit. For more 
information on the GPI04 pin, refer to Chapter 4. 


PCI Cache Mode 

The SYM53C875 supports the PCI specification 
for an 8-bit Cache Line Size register located in 
PCI configuration space. The Cache Line Size reg¬ 
ister provides the ability to sense and react to non- 
aligned addresses corresponding to cache li n e 
boundaries. In conjunction with the Cache Line 
Size register, the PCI commands Read Line, Read 
Multiple, and Write and Invalidate are each soft¬ 
ware enabled or disabled to allow the user full flex¬ 
ibility in using these commands. For more 
information on PCI cache mode operations, refer 
to Chapter 3. 


Load/Store Instructions 

The SYM53C875 supports the Load/Store 
instruction type, which simplifies the movement of 
data between memory and the internal chip regis¬ 
ters. It also enables the SYM53C875 to transfer 
bytes to addresses relative to the DSA register. For 
more information on the Load and Store instruc¬ 
tions, refer to Chapter 6. 


3.3 Volt/5 Volt PCI Interface 

The SYM53C875 can attach directly to a 3.3 Volt 
or a 5 Volt PCI interface, due to separate Vj^d pins 
for the PCI bus drivers. This allows the devices to 
be used on the universal board recommended by 
the PCI Special Interest Group. 

Additional Access to 
General Purpose Pins 

The SYM53C875 can access the GPIOO and 
GPIOl general purpose pins through register bits 
in the PCI configuration space, instead of using 
the GPCNTL register in the operating register 
space to control these pins. In the Symbios Logic 
SDMS software, the configuration bits control 
pins as the clock and data lines, respectively. 

To access the GPIOl-0 pins through the configu¬ 
ration space, connect a 4.7 Kfl resistor between 
the MAD(7) pin and MAD(7) contains an 
internal pull-up that is sensed shortly after chip 
reset. If the pin is sensed high, GPIOl-0 access is 
disabled; if it is low, GPIOl-0 access is enabled. 
Additionally, if GPIOl-0 access has been enabled 
through the MAD(7) pin and if GPIOO and/or 
GPIOl are sensed low after chip reset, GPIOl-0 
access will be disabled. If GPIOl-0 access through 
configuration space is enabled, the GPIOO and 
GPIOl pins cannot be controlled from the 
GPCNTL and GPREG registers, but will be 
observable from the GPREG register. When 
GPIOl-0 access is enabled, the Serial Interface 
Control register at configuration addresses 34-35h 
controls the GPIOO and GPIO1 pins. For more 
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information on GPIOl-0 access, refer to the Serial 
Interface Control register description in Chapter 
3. For more information on the GPIOl-0 pins, see 
Chapter 4. 

JTAG Boundary Scan 
Testing 

The SYM 53C875J/53C875N/53C875JB include 
support for JTAG boundary scan testing in accor¬ 
dance with the IEEE 1149.1 specification, with 
one exception that is discussed in this section. The 
device can accept all required boundary scan 
instructions, as well as the optional CLAMP, 
HIGHZ, and IDCODE instructions. 

The SYM 53C875J/53C875N/53C875JB use an 
8-bit instruction register to support all boundary 
scan instructions. The data registers included in 
the device are the Boundary Data register, the 
IDCODE register, and the Bypass register. The 
device can handle a 10 MHzTCK firequency for 
TDO andTDI. 

Due to design constraints, the RST/ pin (System 
Reset) will always tri-state the SCSI pins when it is 
asserted. This action cannot be controlled by the 
boundary scan logic, and thus is not compliant 
with the specification. There are two solutions that 
resolve this issue: 

1. Use the RST/ pin as a boundary scan 
compliance pin. When the pin is deasserted, 
the device is boundary scan compliant and 
when asserted, the device is non-compliant. To 
maintain compliance, the RST/ pin must be 
driven high. 

2. When RST/ is asserted during boundary scan 
testing, the expected output on the SCSI pins 
must be a high-z condition, and not what is 
contained in the boundary scan data registers 
for the SCSI pin output cells. 

Because of package limitations, the SYM53C875J/ 
53C875JB replaces theTESTIN, MAC/ 
_TESTOUT, BIG_Lrr/, and SDIRPl signals with 
the JTAG boundary scan signals. The 
SYM53C875N includes support for these signals 
in addition to the JTAG pins. 


Big and Little Endian 
Support 

The SYM53C875/53C875N supports both Big 
and Little Endian byte ordering through pin selec¬ 
tion. The 53C875J/53C875JB operates in Little 
Endian mode only (the BIG_OT pin is replaced 
by one of the JTAG boundary scan signals). In Big 
Endian mode, the first byte of an aligned SCSI-to- 
PCI transfer will be routed to lane three and suc¬ 
ceeding transfers will be routed to descending 
lanes. This mode of operation also applies to data 
transfers over the add-in ROM interface. The b 3 ^e 
of data accessed at location OOOOh firom memory is 
routed to lane three, and the data at location 
0003h is routed to b54:e lane 0. In Little Endian 
mode, the first b 5 rte of an aligned SCSI to PCI 
transfer will be routed to lane zero and succeeding 
transfers will be routed to ascending lanes. This 
mode of operation also applies to the add-in ROM 
interface. The byte of data accessed at location 
OOOOh firom memory is routed to lane zero, and the 
data at location 0003h is routed to byte lane 3. 

The Big_Lit pin gives the SYM53C875 the flexi¬ 
bility of operating with either Big or Little Endian 
byte orientation. Internally, in either mode, the 
actual b34:e lanes of the DMA FIFO and registers 
are not modified. The SYM53C875 supports slave 
accesses in Big or Little Endian mode. 

When a dword is accessed, no repositioning of the 
individual bytes is necessary since dwords are 
addressed by the address of the least significant 
byte. SCRIPTS always uses dwords in 32-bit sys¬ 
tems, so compatibility is maintained between sys¬ 
tems using different byte orientations. When less 
than a dword is accessed, individual bytes must be 
repositioned. Internally, the SYM53C875 adjusts 
the b34:e control logic of the DMA FIFO and regis¬ 
ter decodes to access the appropriate byte lanes. 
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The registers will always appear on the same byte 
lane, but the address of the register will be reposi¬ 
tioned. 

Big/Little Endian mode selection has the most 
effect on individual byte access. Internally, the 
SYM53C875 adjusts the byte control logic of the 
DMA FIFO and register decodes to enable the 
appropriate byte lane. The registers will always 
appear on the same byte lane, but the address of 
the register will be repositioned. 

Data to be transferred between system memory 
and the SCSI bus always starts at address zero and 
continues through address ‘n’ - there is no byte 
ordering in the chip. The first byte in firom the 
SCSI bus goes to address 0, the second to address 
1, etc. Going out onto the SCSI bus, address zero 
is the first byte out on the SCSI bus, address 1 is 
the second byte, etc. The only difference is that in 
a Little Endian system, address 0 will be on byte 
lane 0, and in Big Endian mode address zero will 
be on byte lane 3. 

Correct SCRIPTS will be generated if the 
SCRIPTS compiler is run on a system that has the 
same byte ordering as the target system. Any 
SCRIPTS patching in memory must patch the 
instruction with the byte ordering that the 
SCRIPTS processor expects. 

Software drivers for the SYM53C875 should 
access registers by their logical name (i.e., 
SCNTLO) rather than by their address.The logical 
name should be equated to the register’s Big 
Endian address in Big Endian mode (SCNTLO = 
03h), and its Little Endian address in Little 
Endian Mode (SCNTLO = 00h).This way, there is 
no change to the software when moving firom one 
mode to the other; only the equate statement set¬ 
ting the operating modes needs to be changed. 

Addressing of registers from within a SCRIPTS 
instruction is independent of bus mode. Internally, 
the SYM53C875 always operates in Little Endian 
mode. 


Loopback Mode 

The SYM53C875 loopback mode allows testing of 
both initiator and target functions and, in effect, 
lets the chip communicate with itself. When the 
Loopback Enable bit is set in the STESTl register, 
the SYM53C875 allows control of all SCSI sig¬ 
nals, whether the SYM53C875 is operating in ini¬ 
tiator or target mode. For more information on 
this mode of operation, refer to the SYM53C8XX 
Family Programming Guide. 


Parity Options 

The SYM53C875 implements a flexible parity 
scheme that allows control of the parity sense, 
allows parity checking to be turned on or off, and 
has the ability to deliberately send a byte with bad 
parity over the SCSI bus to test parity error recov¬ 
ery procedures. Table 2-1 defines the bits that are 
involved in parity control and observation. Table 2- 
2 describes the parity control fiinction of the 
Enable Parity Checking and Assert SCSI Even 
Parity bits in the SCNTLO register. Table 2-3 
describes the options available when a parity error 
occurs. 

The SYM53C875N has four additional parity pins 
for checking incoming data on the PCI bus. These 
pins are assigned to each byte of the PCI address/ 
data bus, and work in addition to the PAR (PCI 
parity) pin. In PCI master read or slave write oper¬ 
ations, each byte of incoming data on the PCI bus 
is checked against its corresponding parity line, in 
addition to the normal parity checking against the 
PCI PAR signal. In PCI master write or slave read 
operations, parity is generated for each byte. This 
extra parity checking is always enabled for the 
SYM53C875N.The host system must support 
these pins. This feature is not register selectable. A 
parity error on any Byte Parity pin for PCI master 
read or slave write operations will cause a fatal 
DMA interrupt; SCRIPTS will stop running. This 
interrupt can be masked with the EBPE Interrupt 
Enable bit, bit 1 in the DIEN register. These addi¬ 
tional parity pins in no way affect the generation or 
checking of the PCI specified parity line. 
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Functional Description 

Parity Options 


Table 2-2; Bits Used for Parity Control and Generation 


Bit Name 

Location 

Description 

Assert SATN/ on 
Parity Errors 

SCNTLO, Bit 1 

Causes the SYM53C875 to automatically assert SATN/ when it 
detects a parity error while operating as an initiator. 

Enable Parity 
Checking 

SCNTLO, Bit 3 

Enables the SYM53C875 to check for parity errors. The 
SYM53C875 checks for odd parity. This bit also checks for par¬ 
ity errors on the four additional parity pins on the 

SYM53C875N. 

Assert Even SCSI 
Parity 

SCNTLl,Bit2 

Determines the SCSI parity sense generated by the 

SYM53C875 to the SCSI bus. 

Disable Halt on 
SATN/ or a Parity 
Error (Target Mode 
Only) 

SCNTLl, Bit 5 

Causes the SYM53C875 not to halt operations when a parity 
error is detected in target mode. 

Enable Parity Error 
Interrupt 

SIENO, Bit 0 

Determines whether the SYM53C875 will generate an interrupt 
when it detects a SCSI parity error. 

Parity Error 

SISTO, Bit 0 

This status bit is set whenever the SYM53C875 has detected a 
parity error on the SCSI bus. 

Status of SCSI 

Parity Signal 

SSTATO, Bit 0 

This status bit represents the active high current state of the 

SCSI SDPO parity signal. 

SCSI SDPl Signal 

SSTAT2, Bit 0 

This bit represents the active high current state of the SCSI 

SDPl parity signal. 

Latched SCSI Parity 

SSTAT 2, Bit 3 and 
SSTATl,Bit3 

These bits reflect the SCSI odd parity signal corresponding to 
the data latched into the SIDL register 

Master Parity Error 
Enable 

CTEST4, Bit 3 

Enables parity checking during master data phases. 

Master Data Parity 
Error 

DSTAT, Bit 6 

Set when the SYM53C875 as a master detects that a target 
device has signalled a parity error during a data phase. 

Master Data Parity 
Error Interrupt 

Enable 

DIEN, Bit 6 

By clearing this bit^ a Master Data Parity Error will not cause 
IRQ/ to be asserted^ but the status bit will be set in the DSTAT 
register. 

Extended Byte Par¬ 
ity Error Interrupt 
Enable (53C875N 
only) 

DIEN, Bit 1 

By clearing this bit^ an Extended Byte Parity Error will not cause 
IRQ/ to be asserted^ but the status bit will be set in the DSTAT 
register. 
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Parity Options 


Table 2-3: SCSI Parity Control 


EPC 

AESP 

Description 

0 

0 

Will not check for parity errors. Parity is generated when send¬ 
ing SCSI data. Asserts odd parity when sending SCSI data. 

0 

1 

Will not check for parity errors. Parity is generated when send¬ 
ing SCSI data. Asserts even parity when sending SCSI data. 

1 

0 

Checks for odd parity on SCSI data received. Parity is generated 
when sending SCSI data. Asserts odd parity when sending SCSI 
data. 

1 

1 

Checks for odd parity on SCSI data received. Parity is generated 
when sending SCSI data. Asserts even parity when sending 

SCSI data. 

Key: 
EPC = 
ASEP 

Enable Parity Checking (bit 3 SCNTLO) 

= Assert SCSI Even Parity (bit 2 SCNTLl) 


This table only applies when the Enable Parity Checking bit is seL 


Table 2-4s 

SCSI Parity Errors and Interrupts 

DHP 

PAR 

Description 

0 

0 

Will halt when a parity error occurs in target or initiator mode 
and will NOT generate an interrupt. 

0 

1 

Will halt when a parity error occurs in target mode and will gen¬ 
erate an interrupt in target or initiator mode. 

1 

0 

Will not halt in target mode when a parity error occurs until the 
end of the transfer. An interrupt will not be generated. 

1 

1 

Will not halt in target mode when a parity error occurs until the 
end of the transfer. An interrupt will be generated. 

Key: DHP = Disable Halt on SATNI or Parity Error (bit 5 SCNTLl) PAR = Parity Error (bit 0 SIENO) 
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Functional Description 

DMA FIFO 


DMA FIFO 

The DMA FIFO is 4 bjrtes wide by 134 transfers 
deep. The DMA FIFO is illustrated in Figure 2-1. 
To assure compatibility with older products in the 
SYM53C8XX family, the user may set the DMA 
FIFO size to 88 bytes by clearing the DMA FIFO 
Size bit, bit 5 in the CTEST5 register. 



Figure 2-1; DMA FIFO Sections 
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Functional Description 

DMA FIFO 


Data Paths 

The data path through the SYM53C875 is depen¬ 
dent on whether data is being moved into or out of 
the chip) and whether SCSI data is being trans¬ 
ferred asynchronously or synchronously. 

Figure 2-2 shows how data is moved to/from the 
SCSI bus in each of the different modes. 

The following steps determine if any bytes remain 
in the data path when the chip halts an operation: 

Asynchronous SCSI Send 

1 o If the DMA FIFO size is set to 88 bytes^ look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register fi:om the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between zero 
and 88. 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO B 5 ^e 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 536. 

2. Read bit 5 in the SSTATO and SSTAT2 

registers to determine if any bytes are left in the 
SODL register. If bit 5 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODL register is 
full, respectively. Checking this bit also reveals 
bytes left in the SODL register from a Chained 
Move operation with an odd b 5 ^e count. 


Synchronous SCSI Send 

1 0 If the DMA FIFO size is set to 88 bytes, look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register fi:om the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between zero 
and 88. 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 536. 

2. Read bit 5 in the SSTATO and SSTAT2 
registers to determine if any bytes are left in the 
SODL register. If bit 5 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODL register is 
fiill, respectively. Checking this bit also reveals 
bytes left in the SODL register from a Chained 
Move operation with an odd b 5 ^e count. 

3. Read bit 6 in the SSTATO and SSTAT2 
registers to determine if any bytes are left in the 
SODR register. If bit 6 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODR register is 
full, respectively. 


SYM53C875 Data Manual 


2-11 



Functional Description 

DMA FIFO 


Asynchronous SCSI Receive 

1. If the DMA FIFO size is set to 88 bjrtes, look 
at the DFIFO and DBG registers and calculate 
if there are b 5 n:es left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBG register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between 0 and 
88 . 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the GTEST5 register), subtract 
the 10 least significant bits of the DBG register 
from the 10-bit value of the DMA FIFO Byte 
Offset Gounter, which consists of bits 1-0 in 
the GTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
b 5 n;e count between 0 and 536. 

2. Read bit 7 in the SSTATO and SSTAT2 
register to determine if any bytes are left in the 
SIDL register. If bit 7 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte is full, respectively. 

3. If any wide transfers have been performed 
using the Ghained Move instruction, read the 
Wide SGSI Receive bit (SGNTL2, bit 0) to 
determine whether a byte is left in the SWIDE 


register. 

Synchronous SCSI Receive 

1. If the DMA FIFO size is set to 88 b 5 ^es, 
subtract the seven least significant bits of the 
DBG register from the 7-bit value of the 
DFIFO register. AND the result with 7Fh for a 
byte count between 0 and 88. 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the GTEST5 register), subtract 
the 10 least significant bits of the DBG register 
from the 10-bit value of the DMA FIFO Byte 
Offset Gounter, which consists of bits 1-0 in 
the GTEST5 register and bits 7-0 of the DAIA 
FIFO register. AND the result with 3FFh for a 
b37te count between 0 and 536. 

2. Read bits 7-4 of the SSTATl register and bit 4 
of the SSTAT2 register, the binary 
representation of the number of valid bytes in 
the SGSI FIFO, to determine if any bytes are 
left in the SGSI FIFO. 

3. If any wide transfers have been performed 
using the Ghained Move instruction, read the 
Wide SGSI Receive bit (SGNTL2, bit 0) to 
determine whether a byte is left in the SWIDE 
register. 



Figure 2-2; SYM53C875 Host Interface Data Paths 
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Functional Description 

SCSI Bus Interface 


SCSI Bus Interface 

The SYM53C875 supports both single-ended and 
differential operation. 

All SCSI signals are active low.The SYM53C875 
contains the single-ended output drivers and can 
be connected directly to the SCSI bus. Each out¬ 
put is isolated from the power supply to ensure 
that a powered-down SYM53C875 has no effect 
on an active SCSI bus (CMOS ^Voltage feed¬ 
through” phenomena).TolerANT technology pro¬ 
vides signal filtering at the inputs of SREQ/ and 
SACK/ to increase immunity to signal reflections. 


Differential Mode 

In differential mode^ the SDIR (15-0), SDIRP (1- 
0), IGS,TGS, RSTDIR, BSYDIR, and SELDIR 
signals control the direction of external differen¬ 
tial-pair transceivers. The SYM53C875 is placed 
in differential mode by setting the DIF bit^ bit 5 of 
the STEST2 register (4Eh) . Setting this bit tri¬ 
states the BSY/, SEL/, and RST/ pads so they can 
be used as pure input pins. In addition to the stan¬ 
dard SCSI lines, the following signals are used 
during differential operation by the SYM53C875: 


Signal 

Function 

BSYDIR, SELDIR, 

RSTDIR 

Active high signals used to enable the differential drivers as outputs for SCSI signals BSY/, 
SEL/, and RST/, respectively 

SDIR(15-0), 

SDIRP(l-O) 

Active high signals used to control direction of the differential drivers for SCSI data and par¬ 
ity lines, respectively 

IGS 

Active high signal used to control direction of the differential driver for initiator group sig¬ 
nals ATN/and ACK/ 

TGS 

Active high signal used to control direction of the differential drivers for target group signals 
MSG/, C/D/, I/O/, and REQ/ 

DIFFSENS 

Input to the SYM53C875 used to detect the presence of a single-ended device on a differ¬ 
ential system. If a logical zero is detected on this pin, then it is assumed that a single-ended 
device is on the bus and all SCSI outputs will be tri-stated to avoid damage to the trans¬ 
ceiver. 
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SCSI Bus Interface 


See Figure 2-3 for an example differential wiring 
diagram, in which the SYM53C875 is connected 
to theTI SN75976A differential transceiver. The 
recommended value of the pull-up resistor on the 
REQ/, ACK/, MSG/, C/D/, FO/, ATN/, SDO-7/, 
and SDPO/ lines is 680 £2 when the Active Nega¬ 
tion portion of Symbios LogicTolerANT technol¬ 
ogy is not enabled.WhenTolerANT is enabled, the 
recommended resistor value on the REQ/, ACK/, 
SD7-0/, and SDPO/ signals is 1.5 K£2.The electri¬ 
cal characteristics of these pins change when Toler- 
ANT is enabled, permitting a higher resistor value. 

To interface the SYM53C875 to the 75LBC976, 
connect the DIR pins, as well as IGS andTGS, of 
the SYM53C875 directly to the transceiver 
enables (nDE/RE/). These signals control the 
direction of the channels on the 75LBC976. 

The SCSI bi-directional control and data pins 
(SD7-0/, SDPO/, REQ/, ACK/, MSG/, I_0/, C_D/ 

, and ATN/) of the SYM53C875 connect to the bi¬ 
directional data pins (nA) of the 75LBC976 with a 
pull-up resistor. The three remaining pins, SEIV, 
BSY/, and RST/ are connected to the 75LBC976 
with a pull-down resistor. The pull-down resistors 
are required when the pins (nA) of the 7 5LBC976 
are configured as inputs. When the data pins are 
inputs, the resistors provide a bias voltage to both 
the SYM53C87 pins (SEL/, BSY/, and RST/) and 
the 75LBC976 data pins. Because the SEIV, BSY/, 
and RST/ pins on the SYM53C875 are inputs 


only, this configuration allows for the SEIV, BSY/, 
and RST/ SCSI signals to be asserted on the SCSI 
bus. The differential pairs on the SCSI bus are 
reversed when connected to the 75LBC976, due 
to the active low nature of the SCSI bus. 

The pull-up value should be no lower than the 
transceiver Iql can tolerate, but not so high as to 
cause RC timing problems. 

Note: the TISN75976A differential transceiver 

must be used to achieve UltraSCSI transfer 
rates. 

8 -bit/ 16 “bit SCSI and the Differential 
Interface 

In an 8-bit SCSI bus, the SD15-8 pins on the 
SYM53C875 should be pulled up with a 1.5 K£2 
resistor or terminated like the rest of the SCSI bus 
lines. This is very important, as errors may occur 
during reselection if these lines are left floating. In 
the SYM53C875J and SYM53C875JB, the SDIRPl 
pin is replaced by theTCK JTAG signal. If the device is 
used in a wide differential system, use the SDIRPO pin 
to control the direction of the differential transceiver for 
both the SPO and SPl signals. The SDIRPO signal is 
capable of driving both direction inputs from a trans¬ 
ceiver. 
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Functional Description 

SCSI Bus Interface 


Terminator 

Networks 

The terminator networks provide the biasing 
needed to pull signals to an inactive voltage level, 
and to match the impedance seen at the end of the 
cable with the characteristic impedance of the 
cable. Terminators must be installed at the extreme 
ends of the SCSI chain, and only at the ends; no 
system should ever have more or less than two ter¬ 
minators installed and active. SCSI host adapters 
should provide a means of accommodating termi¬ 
nators. The terminators should be socketed, so 
that if not needed they may be removed, or there 
should be a means of disabling them with software. 


Single-ended cables can use a 220 Q pull-up to the 
terminator power supply (Term-Power) line and a 
330 pull-down to Ground. Because of the high- 
performance nature of the SYM53C875, Regu¬ 
lated (or Active) termination is recommended. 
Figure 2-4 shows a Unitrode active terminator. For 
additional information, refer to the SCSI-2 Speci¬ 
fication. TolerANT active negation can be used 
with either termination network. 

Note: if the SYM53C875 is to be used in a design 
with only an 8-bit SCSI bus, all 16 data 
lines still must be terminated or pulled 
high. 

Note: active termination is required for 
UltraSCSI s 5 mchronous transfers. 
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SDO (J1.40) 
SD1 (J1.41) 
SD2 (J1.42) 
SD3 (J1.43) 
SD4 (J1.44) 
SD5 (J1.45) 
SD6 (J1.46) 
SD7 (J1.47) 
SDP0(J1.48) 

ATN (J1.55) 
BSY (J1.57) 
ACK (J1.58) 
RST (J1.59) 
MSG(J1.60) 
SEL(J1.61) 
C/D(J1.62) 
REQ (J1.63) 
I/O (J1.64) 



SD15(J1.38) 
SD14(J1.37) 
SD13(J1.36) 
SD12 {J1.35) 
SD11 (J1.68) 
SD10(J1.67) 
SD9(J1.66) 
SD8 (J1.65) 
SDP1 (J1.39) 


Key 


Cl 

10 |4F SMT 

C2 

0.1 mFSMT 

C3 

2.2 mF SMT 

J1 

68-pin, high density “P” connector 


Figure 2-4: Regulated Termination 
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Functional Description 

Synchronous Operation 


(Re) Select During 
(Re) Selection 

In multi-threaded SCSI I/O environments, it is not 
uncommon to be selected or reselected while try¬ 
ing to perform selection/reselection. This situation 
may occur when a SCSI controller (operating in 
initiator mode) tries to select a target and is rese¬ 
lected by another. The Select SCRIPTS instruc¬ 
tion has an alternate address to which the 
SCRIPTS will jump when this situation occurs. 
The analogous situation for target devices is being 
selected while trying to perform a reselection. 

Once a change in operating mode occurs, the initi¬ 
ator SCRIPTS should start with a Set Initiator 
instruction or the target SCRIPTS should start 
with a Set Target instruction. The Selection and 
Reselection Enable bits (SCID bits 5 and 6, 
respectively) should both be asserted so that the 
SYM53C875 may respond as an initiator or as a 
target. If only selection is enabled, the 
SYM53C875 cannot be reselected as an initiator. 
There are also status and interrupt bits in the 
SISTO and SIENO registers, respectively, indicat¬ 
ing that the SYM53C875 has been selected (bit 5) 
and reselected (bit 4). 


Synchronous Operation 

The SYM53C875 can transfer synchronous SCSI 
data in both initiator and target modes. The 
SXFER register controls both the s 5 mchronous off¬ 
set and the transfer period. It may be loaded by the 
CPU before SCRIPTS execution begins, from 
within SCRIPTS via a Table Indirect I/O instruc¬ 
tion, or with a Read-Modify-Write instruction. 

The SYM53C875 can receive data from the SCSI 
bus at a synchronous transfer period as short as 50 
ns, regardless of the transfer period used to send 
data. The SYM53C875 can receive data at one- 
fourth of the divided SCLK frequency. Depending 
on the SCLK frequency, the negotiated transfer 
period, and the synchronous clock divider, the 
SYM53C875 can send synchronous data at inter¬ 
vals as short as 50 ns for UltraSCSI, 100 ns for fast 
SCSI and 200 ns for SCSI-1. 


Determining the 
Data Transfer Rate 

Sjmchronous data transfer rates are controlled by 
bits in two different registers of the SYM53C875. 
A brief description of the bits is provided below. 
Figure 2-5 illustrates the clock division factors 
used in each register, and the role of the register 
bits in determining the transfer rate. 
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Synchronous Operation 


SCNTL3 Register, bits 6-4 (SCF2-0) 

The SCF2-0 bits select the factor by which the fre¬ 
quency of SCLK is divided before being presented 
to the synchronous SCSI control logic.The output 
from this divider controls the rate at which data 
can be received; this rate must not exceed 80 
MHz. The receive rate of synchronous SCSI data 
is 1/4 of the SCF divider output. For example, if 
SCLK is 80MHz and the SCF value is set to 
divide by two, then the maximum rate at which 
data can be received is 10 MHz (80/(2*4) = 10). 

SCNTL3 Register, bits 2-0 (CCF2-0) 

The CCF2-0 bits select the factor by which the 
frequency of SCLK is divided before being pre¬ 
sented to the asynchronous SCSI core logic. This 
divider must be set according to the input clock 
frequency in the table. 

SXFER Register, bits 7-5 (TP2-0) 

TheTP2-0 divider bits determine the SCSI syn¬ 
chronous transfer period when sending sjmchro- 
nous SCSI data in either initiator or target mode. 
This value fiirther divides the output from the 
SCF divider. 

Achieving Optimal SCSI Send Rates 

To achieve optimal synchronous SCSI send tim¬ 
ings, the SCF divisor value should be set high, to 
divide the clock as much as possible before pre¬ 
senting the clock to the TP divider bits in the 
SXFER register. The TP2-0 divider value should 
be as low as possible. For example, with an 80 
MHz clock to achieve a 10 MB/s send rate, the 
SCF bits can be set to divide by 1 and the TP bits 
to divide by 8; or the SCF bits can be set to divide 
by 2 and the TP bits set to divide by 2. Use the sec¬ 
ond option to achieve optimal SCSI timings. 


UltraSCSI 

Synchronous Data Transfers 

UltraSCSI is simply an extension of current Fast 
SCSI-2 synchronous transfer specifications. It 
allows s 5 mchronous transfer periods to be negoti¬ 
ated down as low as 50 ns, which is half the 100 ns 
period allowed under Fast SCSI-2. This will allow 
a maximum transfer rate of 40 MB/s on a 16-bit 
SCSI bus. The SYM53C875 requires an 80MHz 
SCSI clock input to perform UltraSCSI transfers. 
In addition, the following bit values affect the 
chip’s ability to support UltraSCSI s 5 nichronous 
transfer rates: 

1. Clock Conversion Factor bits, SCNTL3 
register bits 2-0 and S 5 mchronous Clock 
Conversion Factor bits, SCNTL3 register bits 
6-4. These fields now support a value of 101 
(binary), allowing the SCLK frequency to be 
divided down by 4. This allows systems using 
an 80 MHz clock or the internal clock doubler 
to operate at Fast SCSI-2 transfer rates as well 
as UltraSCSI rates, if needed. 

2. Fast-20 Mode Enable bit, SCNTL 3 register 
bit 7. Setting this bit enables UltraSCSI 
synchronous transfers in systems that have an 
80MHz clock or use the internal SCSI clock 
doubler. 
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Example: 

SCLK=80 MHz, SCF=1, XFERP=4, 

SCSI send rate=SCLK/(SCF * XFERP) 

SCSI receive rate= SCLK/(SCF * 4) 

(80 MHz- 5- l=synchronous core rate) 

(80 MHz- 5-4=20 MHz synchronous rate=40MB/s on a 
16-bit SCSI bus) 


Figure 2-5: Determining the Synchronous Transfer Rate 
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Interrupt Handling 

The SCRIPTS processor in the SYM53C875 per¬ 
forms most functions independently of the host 
microprocessor. However, certain interrupt situa¬ 
tions must be handled by the external micropro¬ 
cessor. This section explains all aspects of 
interrupts as they apply to the SYM53C875. 


Polling and 
Hardware Interrupts 

The external microprocessor is informed of an 
interrupt condition by polling or hardware inter¬ 
rupts. Polling means that the microprocessor must 
continually loop and read a register until it detects 
a bit set that indicates an interrupt. This method is 
the fastest, but it wastes CPU time that could be 
used for other system tasks. The preferred method 
of detecting interrupts in most systems is hardware 
interrupts. In this case, the SYM53C875 will 
assert the Interrupt Request (IRQ/) line that will 
interrupt the microprocessor, causing the micro¬ 
processor to execute an interrupt service routine. A 
hybrid approach would use hardware interrupts for 
long waits, and use polling for short waits. 


Registers 

The registers in the SYM53C875 that are used for 
detecting or defining interrupts are the ISTAT, 
SISTO, SISTl, DSTAT, SIENO, SIENl, 

DCNTL, and DIEN. 

ISTAT 

The ISTAT is the only register that can be 
accessed as a slave during SCRIPTS operation, 
therefore it is the register that is polled when 
polled interrupts are used. It is also the first regis¬ 
ter that should be read when the IRQ/ pin has been 
asserted in association with a hardware interrupt. 
The INTF (Interrupt on the Fly) bit should be the 
first interrupt serviced. It must be written to one to 
be cleared. This interrupt must be cleared before 
servicing any other interrupts. If the SIP bit in the 
ISTAT register is set, then a SCSI-type interrupt 
has occurred and the SISTO and SISTl registers 


should be read. If the DIP bit in the ISTAT regis¬ 
ter is set, then a DMA-type interrupt has occurred 
and the DSTAT register should be read. SCSI- 
type and DMA-type interrupts may occur simulta¬ 
neously, so in some cases both SIP and DIP may 
be set. 

SISTO and SISTl 

The SISTO and SISTl registers contain the SCSI- 
type interrupt bits. Reading these registers will 
determine which condition or conditions caused 
the SCSI-t 5 ^e interrupt, and will clear that SCSI 
interrupt condition. If the SYM53C875 is receiv¬ 
ing data from the SCSI bus and a fatal interrupt 
condition occurs, the SYM53C875 will attempt to 
send the contents of the DMA FIFO to memory 
before generating the interrupt. If the 
SYM53C875 is sending data to the SCSI bus and 
a fatal SCSI interrupt condition occurs, data could 
be left in the DMA FIFO. Because of this the 
DMA FIFO Empty (DFE) bit in DSTAT should 
be checked. If this bit is clear, set the CU (Clear 
DMA FIFO) and CSF (Clear SCSI HFO) bits 
before continuing. The CLF bit is bit 2 in 
CTEST3.The CSF bit is bit 1 in STEST3. 

DSTAT 

The DSTAT register contains the DMA-type 
interrupt bits. Reading this register will determine 
which condition or conditions caused the DMA- 
type interrupt, and will clear that DMA interrupt 
condition. Bit 7 in DSTAT, DFE, is purely a status 
bit; it will not generate an interrupt under any cir¬ 
cumstances and will not be cleared when read. 
DMA interrupts will flush neither the DMA nor 
SCSI FIFOs before generating the interrupt, so 
the DFE bit in the DSTAT register should be 
checked after any DMA interrupt. If the DFE bit 
is clear, then the FIFOs must be cleared by setting 
the CLF (Clear DMA FIFO) and CSF (Clear 
SCSI FIFO) bits, or flushed by setting the FLF 
(Flush DMA FIFO) bit. 

SIENO and SIENl 

The SIENO and SIEN1 registers are the interrupt 
enable registers for the SCSI interrupts in SISTO 
and SISTl. 
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DIEN 

The DIEN register is the interrupt enable register 
for DMA interrupts in DSTAT. 

DCNTL 

When bit 1 in this register is set, the IRQ/ pin will 
not be asserted when an interrupt condition 
occurs. The interrupt is not lost or ignored, but 
merely masked at the pin. Clearing this bit when 
an interrupt is pending will immediately cause the 
IRQ/ pin to assert. As with any register other than 
ISTAT, this register cannot be accessed except by a 
SCRIPTS instruction during SCRIPTS execution. 


Fatal vs. Non-Fatal 
Interrupts 

A fatal interrupt, as the name implies, always 
causes SCRIPTS to stop running. All non-fatal 
interrupts become fatal when they are enabled by 
setting the appropriate interrupt enable bit. Inter¬ 
rupt masking will be discussed later in this section. 
All DMA interrupts (indicated by the DIP bit in 
ISTAT and one or more bits in DSTAT being set) 
are fatal. 

Some SCSI interrupts (indicated by the SIP bit in 
the ISTAT and one or more bits in SISTO or 
SISTl being set) are non-fatal. When the 
SYM53C875 is operating in Initiator mode, only 
the Function Complete (CAIP), Selected (SEL), 
Reselected (RSL), General Purpose Timer Expired 
(GEN), and Handshake to Handshake Timer 
Expired (HTH) interrupts are non-fatal. When 
operating in Target mode CAIP, SEL, RSL, Target 
mode: SATN/ active (M/A), GEN, and HTH are 
non-fatal. Refer to the description for the Disable 
Halt on a Parity Error or SATN/ active (Target 
Mode Only) (DHP) bit in the SCNTLl register to 
configure the chip’s behavior when the SATN/ 
interrupt is enabled during Target mode operation. 
The Interrupt on the Fly interrupt is also non- 
fatal, since SCRIPTS can continue when it occurs. 

The reason for non-fatal interrupts is to prevent 
SCRIPTS firom stopping when an interrupt occurs 
that does not require service from the CPU. This 


prevents an interrupt when arbitration is complete 
(CAIP set), when the SYM53C875 has been 
selected or reselected (SEL or RSL set), when the 
initiator has asserted ATN (target mode: SATN/ 
active), or when the General Purpose or Hand¬ 
shake to Handshake timers expire. These inter¬ 
rupts are not needed for events that occur during 
high-level SCRIPTS operation. 


Masking 

Masking an interrupt means disabling or ignoring 
that interrupt. Interrupts can be masked by clear¬ 
ing bits in the SIENO and SIENl (for SCSI inter¬ 
rupts) registers or DIEN (for DAIA interrupts) 
register. How the chip will respond to masked 
interrupts depends on: whether polling or hard¬ 
ware interrupts are being used; whether the inter¬ 
rupt is fatal or non-fatal; and whether the chip is 
operating in Initiator or Target mode. 

If a non-fatal interrupt is masked and that condi¬ 
tion occurs, SCRIPTS will not stop, the appropri¬ 
ate bit in the SISTO or SISTl will still be set, the 
SIP bit in the ISTAT will not be set, and the IRQ/ 
pin will not be asserted. See the section on non- 
fatal vs. fatal interrupts for a list of the non-fatal 
interrupts. 

If a fatal interrupt is masked and that condition 
occurs, then SCRIPTS will still stop, the appropri¬ 
ate bit in the DSTAT, SISTO, or SISTl register 
will be set, and the SIP or DIP bits in the ISTAT 
will be set, but the IRQ/ pin will not be asserted. 

When the chip is initialized, enable all fatal inter¬ 
rupts if you are using hardware interrupts. If a fatal 
interrupt is disabled and that interrupt condition 
occurs, SCRIPTS will halt and the system will 
never know it unless it times out and checks the 
ISTAT after a certain period of inactivity. 

If you are polling the ISTAT instead of using hard¬ 
ware interrupts, then masking a fatal interrupt will 
make no difference since the SIP and DIP bits in 
the ISTAT inform the system of interrupts, not the 
IRQ/ pin. Masking an interrupt after IRQ/ is 
asserted will not cause IRQ/ to be deasserted. 
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Stacked Interrupts 

The SYM53C875 stacks interrupts if they occur 
one after the other. If the SIP or DIP bits in the 
ISTAT register are set (first level), then there is 
already at least one pending interrupt, and any 
future interrupts will be stacked in extra registers 
behind the SISTO, SISTl, and DSTAT registers 
(second level). When two interrupts have occurred 
and the two levels of the stack are full, any further 
interrupts will set additional bits in the extra regis¬ 
ters behind SISTO, SISTl, and DSTAT. When the 
first level of interrupts are cleared, all the inter¬ 
rupts that came in afterward will move into the 
SISTO, SISTl, and DSTAT. After the first inter¬ 
rupt is cleared by reading the appropriate register, 
the IRQ/ pin will be deasserted for a minimum of 
three CLKs; the stacked interrupt(s) will move 
into the SISTO, SISTl, or DSTAT; and the IRQ/ 
pin will be asserted once again. 

Since a masked non-fatal interrupt will not set the 
SIP or DIP bits, interrupt stacking will not occur. 
A masked, non-fatal interrupt will still post the 
interrupt in SISTO, but will not assert the IRQ/ 
pin. Since no interrupt is generated, future inter¬ 
rupts will move right into the SISTO or SISTl 
instead of being stacked behind another interrupt. 
When another condition occurs that generates an 
interrupt, the bit corresponding to the earlier 
masked non-fatal interrupt will still be set. 

A related situation to interrupt stacking is when 
two interrupts occur simultaneously. Since stack¬ 
ing does not occur until the SIP or DIP bits are 
set, there is a small timing window in which multi¬ 
ple interrupts can occur but will not be stacked. 
These could be multiple SCSI interrupts (SIP set), 
multiple DMA interrupts (DIP set), or multiple 
SCSI and multiple DMA interrupts (both SIP and 
DIP set). 

As previously mentioned, DMA interrupts will not 
attempt to flush the FIFOs before generating the 
interrupt. It is important to set either the Clear 


DMA FIFO (CLF) and Clear SCSI FIFO (CSF) 
bits if a DAIA interrupt occurs and the DMA 
FIFO Empty (DFE) bit is not set. This is because 
any future SCSI interrupts will not be posted until 
the DMA FIFO is clear of data. These flocked out' 
SCSI interrupts will be posted as soon as the 
DMA FIFO is empty. 


Halting in an 
Orderly Fashion 

When an interrupt occurs, the SYM53C875 will 

attempt to halt in an orderly fashion. 

■ If the interrupt occurs in the middle of an 
instruction fetch, the fetch will be completed, 
except in the case of a Bus Fault. Execution 
will not begin, but the DSP will point to the 
next instruction since it is updated when the 
current instruction is fetched. 

■ If the DMA direction is a write to memory and 
a SCSI interrupt occurs, the SYM53C875 will 
attempt to flush the DMA FIFO to memory 
before halting. Under any other circumstances 
only the current cycle will be completed before 
halting, so the DFE bit in DSTAT should be 
checked to see if any data remains in the DMA 
FIFO. 

■ SCSI SREQ/SACK handshakes that have 
begun will be completed before halting. 

■ The SYM53C875 will attempt to clean up any 
outstanding synchronous offset before halting. 

■ In the case ofTransfer Control Instructions, 
once instruction execution begins it will 
continue to completion before halting. 

■ If the instruction is a JUMP/CALL WHEN/IF 
<phase>, the DSP will be updated to the 
transfer address before halting. 

■ All other instructions may halt before 
completion. 
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Sample Interrupt 
Service Routine 

The following is a sample of an interrupt service 
routine for the SYM53C875. It can be repeated if 
polling is used, or should be called when the IRQ/ 
pin is asserted if hardware interrupts are used. 

1. ReadlSTAT. 

2. If the INTF bit is set, it must be written to a 
one to clear this status. 

3. If only the SIP bit is set, read SISTO and 
SISTl to clear the SCSI interrupt condition 
and get the SCSI interrupt status. The bits in 
the SISTO and SISTl tell which SCSI 
interrupt(s) occurred and determine what 
action is required to service the interrupt(s). 

4. If only the DIP bit is set, read the DSTAT to 
clear the interrupt condition and get the DMA 
interrupt status. The bits in the DSTAT will 
tell which DMA interrupt (s) occurred and 
determine what action is required to service 
the interrupt(s). 

5. If both the SIP and DIP bits are set, read 
SISTO, SISTl, and DSTAT to clear the SCSI 
and DMA interrupt condition and get the 
interrupt status. If using 8-bit reads of the 
SISTO, SISTl, and DSTAT registers to clear 
interrupts, insert a 12 CLK delay between the 
consecutive reads to ensure that the interrupts 
clear properly. Both the SCSI and DMA 
interrupt conditions should be handled before 
leaving the ISR. It is recommended that the 
DMA interrupt be serviced before the SCSI 
interrupt, because a serious DMA interrupt 
condition could influence how the SCSI 
interrupt is acted upon. 

6. When using polled interrupts, go back to step 
1 before leaving the interrupt service routine, 
in case any stacked interrupts moved in when 
the first interrupt was cleared. When using 
hardware interrupts, the IRQ/ pin will be 
asserted again if there are any stacked 
interrupts. This should cause the system to re¬ 
enter the interrupt service routine. 


Chained Block Moves 

Since the SYM53C875 has the capability to trans¬ 
fer 16- bit wide SCSI data, a unique situation 
occurs when dealing with odd b54:es.The chained 
move (CHMOV) SCRIPTS instruction along with 
the Wide SCSI Send (WSS) and Wide SCSI 
Receive (WSR) bits in the SCNTL2 register are 
used to facilitate these situations. The Chained 
Block Move instruction is illustrated in Figure 2-6. 


Wide SCSI Send 
Bit 

The WSS bit is set whenever the SCSI core is 
sending data (Data Out for initiator or Data In for 
target) and the core detects a partial transfer at the 
end of a chained Block Move SCRIPTS instruc¬ 
tion (this flag will not be set if a normal Block 
Move instruction is used). Under this condition, 
the SCSI core does not send the low-order byte of 
the last partial memory transfer across the SCSI 
bus. Instead, the low-order byte is temporarily 
stored in the lower bjrte of the SODL register and 
the WSS flag is set. The hardware uses the WSS 
flag to determine what behavior must occur at the 
start of the next data send transfer. When the WSS 
flag is set at the start of the next transfer, the first 
bj^e (the high-order byte) of the next data send 
transfer is “married” with the stored low-order 
byte in the SODL register; and the two bytes are 
sent out across the bus, regardless of the t57pe of 
Block Move instruction (normal or chained).The 
flag is automatically cleared when the “married” 
word is sent.The flag can alternately be cleared 
through SCRIPTS or by the microprocessor. 
Additionally, this bit can be used by the micropro¬ 
cessor or SCRIPTS for error detection and recov¬ 
ery purposes. 
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Wide SCSI Receive 
Bit 

The WSR bit is set whenever the SCSI core is 
receiving data (Data In for initiator or Data Out 
for target) and the core detects a partial transfer at 

the end of a block move or chained block move 
SCRIPTS instruction. When WSR is set, the high 
order byte of the last SCSI bus transfer is not 
transferred to memory. Instead, the byte is tempo¬ 
rarily stored in the SWIDE register. The hardware 
uses the WSR bit to determine what behavior must 
occur at the start of the next data receive transfer. 
The bit is automatically cleared at the start of the 
next data receive transfer. The bit can alternatively 
be cleared by the microprocessor or through 
SCRIPTS. The bit can also be used by the micro¬ 
processor or SCRIPTS for error detection and 
recovery purposes. 


SWIDE Register 

This register is used to store data for partial byte 
data transfers. For receive data, the SWIDE regis¬ 
ter holds the high-order byte of a partial SCSI 
transfer which has not yet been transferred to 
memory. This stored data may be a residue b 5 ^e 
(and therefore ignored) or it may be valid data that 
will be transferred to memory at the beginning of 
the next Block Move instruction. 


SODL Register 

For send data, the low-order byte of the SODL 
register holds the low-order byte of a partial mem¬ 
ory transfer which has not yet been transferred 
across the SCSI bus. This stored data is usually 
''married^' with the first hyit of the next data send 
transfer, and both bytes are sent across the SCSI 
bus at the start of the next data send block move 
command. 


Chained Block Move 
SCRIPTS Instruction 

A chained Block Move SCRIPTS instruction is 
primarily used to transfer consecutive data send or 
data receive blocks. Using the chained block move 
instruction facilitates partial receive transfers and 
allows correct partial send behavior without addi¬ 
tional op code overhead. Behavior of the chained 
Block Move instruction varies slightly for sending 
and receiving data. 

For receive data (Data In for initiator or Data Out 
for target), a chained Block Move instruction indi¬ 
cates that if a partial transfer occurred at the end of 
the instruction, the WSR flag is set.The high order 
byte of the last SCSI transfer is stored in the 
SWIDE register rather than transferred to mem¬ 
ory. The contents of the SWIDE register should be 
the first byte transferred to memory at the start of 
the chained block move data stream. Since the 
byte count always represents data transfers to/from 
memory (as opposed to the SCSI bus), the byte 
transferred out of the SWIDE register is one of the 
bytes in the byte count. If the WSR bit is clear 
when a receive data chained Block Move instruc¬ 
tion is executed, the data transfer occurs similar to 
that of the regular block move instruction. Whether 
the WSR bit is set or clear, when a normal block 
move instruction is executed, the contents of the 
SWIDE register will be ignored and the transfer 
takes place normally. For ‘‘N” consecutive wide 
data receive Block Move instructions, the 2nd 
through the Nth Block Move instructions should 
be chained block moves. 

For send data (Data Out for initiator or Data In for 
target), a chained Block Move instruction indicates 
that if a partial transfer terminates the chained 
block move instruction, the last low-order byte 
(the partial memory transfer) should be stored in 
the lower b 5 ^e of the SODL register and not sent 
across the SCSI bus. Without the chained block 
move instruction, the last low-order byte would be 
sent across the SCSI bus. The starting byte count 
represents data bytes transferred from memory but 
not to the SCSI bus when a partial transfer exists. 
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For example, if the instruction is an Initiator 
chained Block Move Data Out of five b 5 ^es (and 
WSS is not previously set), five bytes will be trans¬ 
ferred out of memory to the SCSI core, four bytes 
will be transferred firom the SCSI core across the 
SCSI bus, and one byte will be temporarily stored 
in the lower byte of the SODL register waiting to 
be married with the first byte of the next block 
move instruction. Regardless of whether a chained 
Block Move or normal Block Move instruction is 
used, if the WSS bit is set at the start of a data send 


command, the first byte of the data send command 
is assumed to be the high-order byte and is ^^mar- 
ried^^ with the low-order b 5 ^e stored in the stored 
in the lower byte of the SODL register before the 
two bytes are sent across the SCSI bus. For 
consecutive wide data send Block Move com¬ 
mands, the first through the (Nth - 1) Block Move 
instructions should be Chained Block Moves. 
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Notes: CHMOV 5y 3 when DATAjOUT: Moves five bytes from address 03 in the host memory to the SCSI bus (bytes 03^ 

04, 05, and 06 are moved and byte 07 remains in the low order byte of the 
SCSI Output Data Latch register and is married with the first byte of the fol¬ 
lowing MOVE instruction). 

MOVE 5, 9 when DATA_OUT: Moves five bytes from address 09 in the host memory to the SCSI bus. 


Figure 2-6: Block Move and Chained Block Move Instructions 
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PCI Functional Description 


PCI Addressing 

There are three types of PCI-defined address 
space: 

■ Configuration space 

■ Memory space 

■ FO space 

Configuration space is a contiguous 256 x 8-bit set 
of addresses dedicated to each ‘^slot” or ‘^stub” on 
the bus. Decoding C_BE/(3-0) determines if a PCI 
cycle is intended to access configuration register 
space. The IDSEL bus signal is a ''chip select'' that 
allows access to the configuration register space 
only. A configuration read/write cycle without 
IDSEL will be ignored. The eight lower order 
addresses are used to select a specific 8-bit register. 
AD(10-8) are decoded as well, but they must be 
zero or the SYM53C875 will not respond. Accord¬ 
ing to the PCI specification, AD(10-8) are to be 
used for multifunction devices. The host processor 
uses the PCI configuration space to initialize the 
SYM53C875. 

The lower 128 bytes of the SYM53C875 configu¬ 
ration space holds system parameters while the 
upper 128 bytes map into the SYM53C875 oper¬ 
ating registers. For all PCI cycles except configura¬ 
tion cycles, the SYM53C875 registers are located 
on the 256-byte block boundary defined by the 
base address assigned through the configured reg¬ 
ister. The SYM53C875 operating registers are 
available in both the upper and lower 128-byte 
portions of the 256-byte space selected. 

At initialization time, each PCI device is assigned a 
base address (in the case of the SYM53C875, the 
upper 24 bits of the address are selected) for mem¬ 


ory accesses and FO accesses. On every access, the 
SYM53C875 compares its assigned base addresses 
with the value on the Address/Data bus during the 
PCI address phase. If there is a match of the upper 
24 bits, the access is for the SYM53C875 and the 
low order eight bits define the register to be 
accessed. A decode of C_BE/ (3-0) determines 
which registers and what type of access is to be 
performed. 

PCI defines memory space as a contiguous 32-bit 
memory address that is shared by all system 
resources, including the 

SYM53C875. Base Address Register One deter¬ 
mines which 256-byte memory area this device will 
occupy. 

PCI defines FO space as a contiguous 32-bit FO 
address that is shared by all system resources, 
including the SYM53C875. Base Address Register 
Zero determines which 256-byte FO area this 
device will occupy. 

PCI Bus Commands and 
Functions Supported 

Bus commands indicate to the target the type of 
transaction the master is requesting. Bus com¬ 
mands are encoded on the C_BE/(3-0) lines dur¬ 
ing the address phase. PCI bus command 
encoding and types appear in Table 3-1. 

The FO Read command is used to read data from 
an agent mapped in FO address space. All 32 
address bits are decoded. 

The FO Write command is used to write data to an 
agent when mapped in FO address space. All 32 
address bits are decoded. 
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The Memory Read, Memory Read Multiple, and 
Memory Read Line commands are used to read 
data from an agent mapped in memory address 
space. All 32 address bits are decoded. 

The Memory Write and Memory Write and Invali¬ 
date commands is are used to write data to an 
agent when mapped in memory address space. All 
32 address bits are decoded. 


Table 3-1; PCI Bus Commands and Encoding Types 


C_BE(3-0) 

Command Type 

Supported as Master 


Supported as Slave 

0000 

Special Interrupt Acknowledge 

No 


No 

0001 

Special Cycle 

No 


No 

0010 

I/O Read Cycle 

Yes 


Yes 

0011 

I/O Write Cycle 

Yes 


Yes 

0100 

Reserved 


n/a 


0101 

Reserved 


n/a 


0110 

Memory Read 

Yes 


Yes 

0111 

Memory Write 

Yes 


Yes 

1000 

Reserved 


n/a 


1001 

Reserved 


n/a 


1010 

Configuration Read 

No 


Yes 

1011 

Configuration Write 

No 


Yes 

1100 

Memory Read Multiple 

Yes** 


No (defaults to 0110) 

1101 

Dual Address Cycle 

No 


No 

1110 

Memory Read Line 

Yes* 


No (defaults to 0110) 

nil 

Memory Write and Invalidate 

Yes*** 


No (defaults to 0111) 

This operation is selectable by bit 3 in the DMODE operating register 
"^"^This operation is selectable by bit 2 in the DMODE operating register 
^^^This operation is selectable by bit 0 in the CTEST3 operating register 
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PCI Cache Mode 

The SYM53C875 supports the PCI specification 
for an 8-bit Cache Line Size register located in 
PCI configuration space. The Cache Line Size reg¬ 
ister provides the ability to sense and react to non- 
aligned addresses corresponding to cache line 
boundaries. In conjunction with the Cache Line 
Size register, the PCI commands Read Line, Read 
Multiple, and Write and Invalidate are each soft¬ 
ware enabled or disabled to allow the user full flex¬ 
ibility in using these commands. 


Support for PCI 
Cache Line Size Register 

The SYM53C875 supports the PCI specification 
for an 8-bit Cache Line Size register in PCI config¬ 
uration spacer it can sense and react to non-aligned 
addresses corresponding to cache line boundaries. 


Selection of Cache 
Line Size 

The cache logic will select a cache line size based 
on the values for the burst size in the DMODE 
register and the PCI Cache Line Size register. 

Note: the SYM53C875 will not automatically use 
the value in the PCI Cache Line Size 
register as the cache line size value. The 
chip scales the value of the Cache Line Size 
register down to the nearest binary burst 
size allowed by the chip (2,4, 8,16,32, 64, 
or 128), compares this value to the burst 
size defined by the values of the DMODE 
register and bit 2 of the CTEST5 register, 
then selects the smallest as the value for the 
cache line size.The SYM53C875 will use 
this value for all burst data transfers. 


Alignment 

The SYM53C875 uses the calculated line size 
value to monitor the current address for alignment 
to the cache line size. When it is not aligned, the 
chip attempts to align to the cache boundary by 
using a “smart aligning” scheme. This means that 
it will attempt to use the largest burst size possible 
that is less than the cache line size, to reach the 
cache boundary quickly with no overflow. This 
process is a stepping mechanism that will step up 
to the highest possible burst size based on the cur¬ 
rent address. 

The stepping process begins at a 4-dword bound¬ 
ary. The SYM53C875 will first try to align to a 4- 
dword boundary (0x0000, 0x0008, 0x0010, etc.) 
by using single dword transfers (no bursting). 

Once this boundary has been reached the chip will 
evaluate the current alignment to various burst 
sizes allowed, and will select the largest possible as 
the next burst size, while not exceeding the cache 
line size. The chip will then issue this burst, and re¬ 
evaluate the alignment to various burst sizes, again 
selecting the largest possible while not exceeding 
the cache line size, as the next burst size. This step¬ 
ping process continues until the chip reaches the 
cache line size boundary or runs out of data. Once 
a cache line boundary is reached, the chip will use 
the cache line size as the burst size from then on, 
except in the case of multiples (explained below). 
The alignment process is finished at this point. 

Example: Cache Line Size - 16, 

Current Address = 0x01 

The chip is not aligned to a 4-dword cache bound¬ 
ary (the stepping threshold), so it issues four sin- 
gle-dword transfers (the first is a 3-b57te transfer). 
At address 0x10, the chip is aligned to a 4-dword 
boundary, but not aligned to any higher burst size 
boundaries that are less than the cache line size. 

So, the part will issue a burst of 4. At this point, 
the address is 0x20, and the chip will evaluate that 
it is aligned not only to a 4-dword boundary, but 
also to an 8-dword boundary. It will select the 
highest, 8, and burst 8 dwords. At this point, the 
address is 0x40, which is a cache line size bound¬ 
ary. Alignment stops, and the burst size firom then 
on is switched to 16. 
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Memory Move 
Misalignment 

The SYM53C875 will not operate in a cache 
alignment mode when a Memory Move instruc¬ 
tion type is issued and the read and write addresses 
are diEferent distances from the nearest cache line 
botmdary. For example, if the read address is 
0x2IF and the write address is 0x42F, and the 
cache line size is eight (8), the addresses are b 5 ^e 
aligned, but they are not the same distance from 
the nearest cache boundary. The read address is 1 
b 5 ^e from the cache boundary 0x220 and the write 
address is 17 b 3 ^es from the cache boundary 
0x440. In this situation, the chip will not align to 
cache boundaries and will operate as an 
SYM53C825. 


Memory Write 

and Invalidate Command 

The Memory Write and Invalidate command is 
identical to the Memory Write command, except 
that it additionally guarantees a minimum transfer 
of one complete cache line; i.e., the master intends 
to write all bytes within the addressed cache line in 
a single PCI transaction unless interrupted by the 
target. This command requires implementation of 
the PCI Cache Line Size register at address OCh in 
PCI configuration space.The SYM53C875 
enables Memory Write and Invalidate cycles when 
bit 0 in the CTEST3 register (WRIE) and bit 4 in 
the PCI Command register are set. This will cause 
Memory Write and Invalidate commands to be 
issued when the following conditions are met: 

1. The CLSE bit, WRIE bit, and PCI 
configuration Command register, bit 4 must be 
set. 

2. The cache line size register must contain a 
legal burst size (2, 4, 8, 16, 32, 64, or 128) 
value AND that value must be less than or 
equal to the DMODE burst size. 

3. The chip must have enough bytes in the DMA 
FIFO to complete at least one full cache line 
burst. 


4. The chip must be aligned to a cache line 
boundary. 

When these conditions have been met, the 
SYM53C875 will issue aWrite and Invalidate 
command instead of a Memory Write command 
during all PCI write cycles. 

Multiple Cache Line Transfers 

The Write and Invalidate command can write mul¬ 
tiple cache lines of data in a single bus ownership. 
The chip issues a burst transfer as soon as it 
reaches a cache line boundary. The size of the 
transfer will not automatically be the cache line 
size, but rather a multiple of the cache line size as 
allowed for in the Revision 2.1 of the PCI specifi¬ 
cation. The logic will select the largest multiple of 
the cache line size based on the amount of data to 
transfer, with the maximum allowable burst size 
being that determined from the DMODE Burst 
Size bits and CTEST 5, bit 2. If multiple cache 
line size transfers are not desired, the DMODE 
burst size can be set to exactly the cache line size 
and the chip will only issue single cache line trans¬ 
fers. 

After each data transfer, the chip re-evaluates the 
burst size bsed on the amount of remaining data to 
transfer and again selects the highest possible mul¬ 
tiple of the cache line size, no larger than the 
DMODE burst size. The most likely scenario of 
this scheme is that the chip will select the 
DMODE burst size after alignment, and issue 
bursts of this size. The burst size will, in effect, 
throttle down toward the end of a long Memory 
Move or Block Move transfer until only the cache 
line size burst size is left; the chip will finish the 
transfer with this burst size. 
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Latency 

In accordance with the PCI specification, the 
chip’s latency timer will be ignored when issuing a 
Write and Invalidate command such that when a 
latency time-out has occurred, the 
SYM53C875 will continue to transfer up until a 
cache line boundary. At that point, the chip will 
relinquish the bus, and finish the transfer at a later 
time using another bus ownership. If the chip is 
transferring multiple cache lines it will continue to 
transfer until the next cache boundary is reached. 

PCI Target Retry 

During a Write and Invalidate transfer, if the target 
device issues a retry (STOP with no TRDY, indi¬ 
cating that no data was transferred), the 
SYM53C875 will relinquish the bus and immedi¬ 
ately try to finish the transfer on another bus own¬ 
ership. The chip will issue another Write and 
Invalidate command on the next ownership, in 
accordance with the PCI specification. 

PCI Target Disconnect 

During a Write and Invalidate transfer, if the target 
device issues a disconnect the 
SYM53C875 will relinquish the bus and immedi¬ 
ately try to finish the transfer on another bus own¬ 
ership. The chip will not issue another Write and 
Invalidate command on the next ownership unless 
the address is aligned. 


Memory Read 
Line Command 

This command is identical to the Memory Read 
command, except that it additionally indicates that 
the master intends to fetch a complete cache line. 
This command is intended to be used with bulk 
sequential data transfers where the memory system 
and the requesting master might gain some perfor¬ 
mance advantage by reading up to a cache line 
boundary rather than a single memory cycle.The 
Read Line Mode function that exists in the previ¬ 
ous SYM53C8XX chips has been modified in the 
SYM53C875 to reflect the PCI cache line size reg¬ 


ister specifications. The functionality of the Enable 
Read Line bit (bit 3 in DMODE) has been modi¬ 
fied to more resemble the Write and Invalidate 
mode in terms of conditions that must be met 
before a Read Line command will be issued. How¬ 
ever, the Read Line option will operate exactly like 
the previous SYM53C8XX chips when cache 
mode has been disabled by a CLSE bit reset or 
when certain conditions exist in the chip 
(explained below). 

The Read Line mode is enabled by setting bit 3 in 
the DMODE register. If cache mode has been dis¬ 
abled, Read Line commands will be issued on 
every read data transfer, except op code fetches, as 
in previous SYM53C8XX chips. 

If cache mode has been enabled, a Read Line com¬ 
mand will be issued on all read cycles, except op 
code fetches, when the following conditions have 
been met: 

1. The CLSE and Enable Read Line bits must be 
set. 

2. The Cache Line Size register must contain a 
legal burst size value (2, 4, 8, 16, 32, 64, or 

128) AND that value must be less than or 
equal to the DMODE burst size. 

3. The number of bytes to be transferred at the 
time a cache boundary has been reached must 
be equal to or greater than the DMODE burst 
size. 

4o The chip must be aligned to a cache line 
boundary. 

When these conditions have been met, the chip 
will issue a Read Line command instead of a 
Memory Read during all PCI read cycles. Other¬ 
wise, it will issue a normal Memory Read com¬ 
mand. 
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Memory Read 
Multiple Command 

This command is identical to the Memory Read 
command except that it additionally indicates that 
the master may intend to fetch more than one 
cache line before disconnecting.The SYM53C875 
supports PCI Read Multiple functionality and will 
issue Read Multiple commands on the PCI bus 
when the Read Multiple Mode is enabled. This 
mode is enabled by setting bit 2 of the DMODE 
register (ERMP). If cache mode has been enabled, 
a Read Multiple command will be issued on all 
read cycles, except op code fetches, when the fol¬ 
lowing conditions have been met: 

1. The CLSE and ERMP bits must be set. 

2. The Cache Line Size register must contain a 
legal burst size value (2, 4, 8, 16, 32, 64, or 
128) AND that value must be less than or 
equal to the DMODE burst size. 

3. The number of bytes to be transferred at the 
time a cache boundary has been reached must 
be at least twice the full cache line size. 

4. The chip must be aligned to a cache line 
boundary. 

When these conditions have been met, the chip 
will issue a Read Multiple command instead of a 
Memory Read during all PCI read cycles. 

Burst Size Selection 

The Read Multiple command reads in multiple 
cache lines of data in a single bus ownership. The 
number of cache lines to be read is a multiple of 
the cache line size as allowed for in the Revision 
2,1 of the PCI specification. The logic will select 
the largest multiple of the cache line size based on 
the amount of data to transfer, with the maximum 
allowable burst size being that determined from 
the DMODE Burst Size bits and CTEST 5, bit 2. 


Read Multiple with Read Line Enabled 

When both the Read Multiple and Read Line 
modes have been enabled, the Read Line com¬ 
mand will not be issued if the above conditions are 
met. Instead, a Read Multiple command will be 
issued, even though the conditions for Read Line 
have been met. 

If the Read Multiple mode is enabled and the Read 
Line mode has been disabled. Read Multiple com¬ 
mands will still be issued if the Read Multiple con¬ 
ditions are met. 

Unsupported PCI Commands 

The SYM53C875 does not respond to reserved 
commands, special cycle, dual address cycle, or 
interrupt acknowledge commands as a slave. It will 
never generate these commands as a master. 
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Configuration Registers 

The Configuration registers are accessible 
only by system BIOS during PCI configura¬ 
tion cycles, and are not available to the user 
at any time. No other cycles, including 
SCRIPTS operations, can access these regis¬ 
ters. The lower 128 bytes hold configuration 
data while the upper 128 bytes hold the 
SYM53C875 operating registers, which are 
described in Chapter Five, ‘‘Operating Regis¬ 
ters.” These registers can be accessed by 
SCRIPTS or the host processor. 

Note: the configuration register 

descriptions provide general 


information only, to indicate which PCI 
configuration addresses are supported in the 
SYM53C875.Table 3-2 shows the PCI 
configuration registers implemented by the 
SYM53C875. Addresses 40h through 7Fh are 
not defined. 

All PCI-compliant devices, such as the SYM53C875, 
must support the Vendor ID, Device ID, Command, 
and Status Registers. Support of other PCI-compliant 
registers is optional. In the SYM53C8755 registers that 
are not supported are not writable and will return all 
zeroes when read. Only those registers and bits that 
are currently supported by the SYM53C875 are 
described in this chapter. For more detailed informa¬ 
tion on PCI registers, please see the PCI Specification. 


31 

16 

15 

0 


Device IE 

= OOOFh 

Vendor ID = lOOOh 

OOh 

Status 

Command 

04h 

Class Code = OlOOOOh 

Rev ID = OXh 

08h 

Not Supported 

Header Type 

Latency Timer 

Cache Line 
Size 

OCh 

Base Address Zero (FO) ^ 

lOh 

Base Address One (Memory) 2 

14h 

RAM Base Address^ 

18h 

Not Supported 

iCh 

Not Supported 

20h 

Not Supported 

24h 

Reserved 

28h 

Subsystem Data Register 

2Ch 

Expansion ROM Base Address'^ 

30h 

Reserved 

Reserved 

General Purpose Pin ControP 

34h 

Reserved 

38h 

Max_Lat 

Min_Gnt 

Interrupt Pin 

Interrupt Line 

3Ch 


Figure 3-1: PCI Configuration Register Map 


^I/O Base is supported 
^Memory Base is supported 

Note: Addresses 40h to 7Fh are not defined. All unsupported registers are not writable and will return all zeroes when read. Reserved 
registers wiU also return zeroes when read, 

^This register powers up enabled and can be disabled by puU-down resistors on the MADS pin 
expansion memory is enabled through puU-dozm resistors on the AlA 0(7-0) bus, 

SBoth of these registers default to Reserved and are enabled through puU-down resistors on the MAD(7-6) pins at reset. 
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Register OOh 
Vendor ID 
Read Only 

This field identifies the manufacturer of the device. 
The Symbios Logic Vendor ID is lOOOh. 


Register 02h 
Device ID 
Read Only 

This field identifies the particular device. The 
SYM53C875 device ID is OOOFh. 


Register 04h 

Command 

Read/Write 

The Command Register, illustrated in Figure 3-2, 
provides coarse control over a device’s ability to 
generate and respond to PCI cycles. When a zero is 
written to this register, the SYM53C875 is logi¬ 
cally disconnected from the PCI bus for all 
accesses except configuration accesses. 

In the SYM53C875, bits 3 through 5 and bit 7 and 
9 are not implemented. Bits 10 through 15 are 
reserved. 

Bits 15-9 Reserved 

Bit 8 SERR/ Enable 

This bit enables the SERR/ driver. SERR/ is 
disabled when this bit is clear. The default 
value of this bit is zero. This bit and bit 6 must 
be set to report address parity errors. 

Bit 7 Reserved 

Bit 6 Enable Parity Error Response 

This bit allows the SYM53C875 to detect par¬ 
ity errors on the PCI bus and report these 
errors to the system. Only data parity checking 
is enabled. The SYM53C875 always generates 
parity for the PCI bus. 

Bit 5 Reserved 


Bit 4 Write and Invalidate Mode 

This bit, when set, will cause Memory Write 
and Invalidate cycles to be issued on the PCI 
bus afl:er certain conditions have been met. For 
more information on these conditions, refer to 
the section "Memory Write and Invalidate 
Command". To enable Write and Invalidate 
Mode, bit 0 in the CTEST3 register (operating 
register set) must also be set. 

Bit 3 Reserved 

Bit 2 Enable Bus Mastering 

This bit controls the SYM53C875’s ability to 
act as a master on the PCI bus. A value of zero 
disables the device firom generating PCI bus 
master accesses. A value of one allows the 
SYM53C875 to behave as a bus master. The 
SYM53C875 must be a bus master in order to 
fetch SCRIPTS instructions and transfer data. 

Bit 1 Enable Memory Space 

This bit controls the SYM53C875’s response 
to Memory Space accesses. A value of zero dis¬ 
ables the device response. A value of one allows 
the SYM53C875 to respond to Memory Space 
accesses at the address specified by Base 
Address One. 

Bit 0 Enable I/O Space 

This bit controls the SYM53C875’s response 
to I/O space accesses. A value of zero disables 
the response. A value of one allows the 
SYM53C875 to respond to I/O space accesses 
at the address specified in Base Address Zero. 
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Reserved 
Reserved 
Reserved 
Reserved . 
Reserved _ 
Reserved _ 

Not Implemented _ 

SERR/ Enable _ 



|14 

lis 

|12 

11 

i 

E 

S 

m 


E 

E 

E 

E 

E 

0 


Not Implemented 
Enable Parity Response _ 

Not implemented_ 

Write and Invalidate Mode_ 

Not Implemented_ 


Enable Bus Mastering 
Enable Memory Space . 
Enable I/O Space_ 


Figure 3-2: Command Register Layout 
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Register 06h 

Status 

Read/Write 

The Status Register^ illustrated in Figure 3-35 is 
used to record status information for PCI bus- 
related events. 

In the SYM53C8755 bits 0 through 4 are reserved 
and bits 5^ 6^ 7, and 11 are not implemented by 
the SYM53C875, 

Reads to this register behave normally. Writes are 
slightly different in that bits can be cleared, but not 
set. A bit is reset whenever the register is written, 
and the data in the corresponding bit location is a 
one. For instance, to clear bit 15 and not affect any 
other bits, write the value 8000h to the register. 

Bit 15 Detected Parity Error (from Slave) 

This bit will be set by the SYM53C875 when¬ 
ever it detects a data parity error, even if parity 
error handling is disabled. 

Bit 14 Signaled System Error 

This bit is set whenever a device asserts the 
SERR/ signal. 

Bit 13 Master Abort (from Master) 

This bit should be set by a master device when¬ 
ever its transaction (except for Special Cycle) is 
terminated with master-abort. All master 
devices should implement this bit. 


Bit 12 Received Target Abort (from 
Master) 

This bit should be set by a master device when¬ 
ever its transaction is terminated with a target 
abort. All master devices should implement 
this bit. 

Bit 11 Reserved 

Bits 10-9 DEVSEL/Timing 

These bits encode the timing of DEVSEL/. 
These are encoded as 00b for fast, 01b for 
medium, 10b for slow with 11b reserved. 

These bits are read-only and should indicate 
the slowest time that a device asserts DEVSEL/ 
for any bus command except Configuration 
Read and Configuration Write, In the 
SYM53C875, 01b is supported. 

Bit 8 Data Parity Reported 

This bit is set when the following three condi¬ 
tions are met: 1) The bus agent asserted 
PERR/ itself or observed PERR/ asserted; 2) 
The agent setting this bit acted as the bus mas¬ 
ter for the operation in which the error 
occurred; 3) The Parity Error Response bit in 
the Command register is set. 

Bits 7-0 Reserved 
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Detected Parity Error (from Slave) 
Signaled System Error 
Received Master Abort (from Master) . 
Received Target Abort (from Master) _ 
Reserved (Not Supported) _ 


El 

0 


m 

ID 

1 

i 

m 

m 


B 

i 

IB 

IB 

B 

IB 


DEVSEL timing r 

00 = fast, 01 = medium, 10 = slow 

Data Parity Reported 
Reserved (Not Supported) . 

Reserved_ 

Reserved_ 

Reserved_ 

Reserved_ 

Reserved - 

Reserved _ 

Reserved_ 


Figure 3-3: Status Register Layout 


Register 08h 
Revision ID 
Read Only 

This register specifies device and revision identifi¬ 
ers. In the SYM53C875, the upper nibble will be 
0000b. The lower nibble reflects the current revi¬ 
sion level of the device. It should have the same 
value as the Chip Revision Level bits in the 
CTEST3 register. 


Register 09h 
Class Code 
Read Only 

This register is used to identify the generic fiinc- 
tion of the device. The upper byte of this register is 
a base class code, the middle byte is a subclass 
code, and the lower byte identifies a specific regis¬ 
ter-level programming interface. The value of this 
register is OlOOOOh, which indicates a SCSI con¬ 
troller. 


Register OCh 
Cache Line Size 
Read/Write 

This register specifies the system cache line size in 
units of 32-bit words. Cache mode is enabled and 
disabled by the Cache Line Size Enable (CLSE) 
bit, bit 7 in the DCNTL register. Setting this bit 
causes the SYM53C875 to align to cache line 
boundaries before allowing any bursting, except 
during Memory Moves in which the read and write 
addresses are not aligned to a burst size boundary. 
For more information on this register, see the sec¬ 
tion "Support for PCI Cache Line Size Register". 
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Register ODh 
Latency Timer 
Read/Write 

The Latency Timer register specifies, in units of 
PCI bus clocks, the value of the Latency Timer for 
this PCI bus master.The SYM53C875 supports 
this timer. All eight bits are writable, allowing 
latency values of 0-255 PCI clocks. Use the follow¬ 
ing equation to calculate an optimum latency value 
for the SYM53C875: 

Latency = 2 + (Burst Size * (typical wait states +1)). 
Values greater than optimum are also acceptable. 


Register OEh 
Header Type 
Read Only 

This register identifies the layout of bjrtes lOh 
through 3Fh in configuration space and also 
whether or not the device contains multiple func¬ 
tions. The value of this register is OOh. 


Register lOh 

Base Address Zero (I/O) 

Read/Write 

This 32-bit register has bit zero hardwired to one. 
Bit 1 is reserved and must return a zero on all 
reads, and the other bits are used to map the 
device into I/O space. 


Register 14h 

Base Address One (Memory) 

Read/Write 

This register has bit 0 hardwired to zero. For 
detailed information on the operation of this regis¬ 
ter, refer to the PCI Specification. 


Register 18h 
RAM Base Address 
Read/Write 

This register holds the memory base address of the 
4 KB internal RAM. The user can read this regis¬ 
ter through the SCRATCHB register in the oper¬ 
ating register set when bit 3 of the CTEST2 
register is set. 


Register 2C-2F 
Subsystem Data 
Read/Write 

This register supports subsystem identification. It 
is byte-addressable and powers up as all zeroes. To 
write to this register, connect a 4.7 KI2 resistor 
between the MAD(6) pin and Vgg.The MAD(6) 
pin contains an internal pull-up and will be sensed 
shortly after the deassertion of Chip Reset. If 
sensed high, the register will always return zeros; if 
sensed low, the register can be written with non¬ 
zero values. 


Register 30h 

Expansion ROM Base Address 
Read/Write 

This four-b 5 ^e register handles the base address 
and size information for expansion ROM. It fianc- 
tions exactly like the Base Address Zero and Base 
Address One registers, except that the encoding of 
the bits is different. The upper 21 bits correspond 
to the upper 21 bits of the expansion ROM base 
address. 

The Expansion ROM Enable bit, bit 0, is the only 
bit defined in this register. This bit is used to con¬ 
trol whether or not the device accepts accesses to 
its expansion ROM. When the bit is set, address 
decoding is enabled, and a device can be used with 
or without an expansion ROM depending on the 
system configuration. To access the external mem¬ 
ory interface, the Memory Space bit in the Com¬ 
mand register must also be set. 
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The host system detects the size of the external 
memory by first writing the Expansion ROM Base 
Address register with all ones and then reading 
back the register. The SYM53C875 will respond 
with zeros in all don’t care locations. The ones in 
the remaining bits represent the binary version of 
the external memory size. For example, to indicate 
an external memory size of 32 KB, this register, 
when written with ones and read back, will return 
ones in the upper 17 bits. 


Register 34-35h 

General Purpose Pin Control 

Read/Write 

This register is enabled if the SYM53C875 is con¬ 
figured to access a serial EEPROM. If serial 
EEPROM access is enabled, the least significant 
bit at address 34h will be set, indicating that the 
SYM53C875 is serial EEPROM-capable. Regis¬ 
ter 35h will contain the direction control and bit 
values associated with the serial clock and data, 
defined below. 

Bit 5 GPIOl Control 

This bit contains the direction control for the 
GPIO1 pin. This bit powers up clear, indicat¬ 
ing that GPIO 1 is an input. Setting this direc¬ 
tion bit will cause GPIOl to become an 
output. 

Bit 4 GPIOO Control 

This bit contains the direction control for the 
GPIOO pin. This bit powers up clear, indicat¬ 
ing that GPIOO is an input. Setting this direc¬ 
tion bit will cause GPIOO to become an 
output. 

Bit 1 GPIOl Value 

This bit contains the value which will be avail¬ 
able on GPIOl. 

Bit 0 GPIOO Value 

This bit contains the value which will be avail¬ 
able on GPIOO. 

All bits in registers 34h and 35h will be cleared if 
GPIO 1-0 access is disabled.. 


Register 3Ch 
Interrupt Line 
Read/Write 

This register is used to communicate interrupt line 
routing information. POST software will write the 
routing information into this register as it initiates 
and configures the system. The value in this regis¬ 
ter tells which input of the system interrupt con- 
troller(s) the device’s interrupt pin has been 
connected to. Values in this register are specified by 
system architecture. 


Register 3Dh 
Interrupt Pin 
Read Only 

This register tells which interrupt pin the device 
uses. Its value is set to Olh, for the INTA/ signal. 


Register 3Eh 
Min_Gnt 
Read Only 


Register 3Fh 
Max_Lat 
Read Only 

These registers are used to specify the desired set¬ 
tings for LatencyTimer values. Min_Gnt is used to 
specify how long a burst period the device needs. 
Max_Lat is used to specify how often the device 
needs to gain access to the PCI bus. The value 
specified in these registers is in units of 0.25 
microseconds. Values of zero indicate that the 
device has no major requirements for the settings 
of Latency Timers. The SYM53C875 sets the 
Min_Gnt register to 1 Ih and the Max_Lat register 
to 40h. 
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Chapter 4 

Signal Descriptions 


This chapter presents the SYM53C875 pin configuration and signal definitions using tables and illustra¬ 
tions. Figure 4-1 through Figure 4-4 are the pin diagrams for all versions of the SYM53C875 and Figure 
4-5 is the functional signal grouping. The pins definitions are presented in Table 4-2 through Table 4-12. 
The SYM53C875 is a pin-for-pin replacement for the SYM53C825. 
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The decoupling capacitor arrangement shown above is recommended to maximize the benefits of the internal split ground system. 
Capacitor values between 0.01 and 0. l\iF should provide adequate noise isolation. Because of the number of high current drivers on 
the SYM53C87S, a multi-layer PC board with power and ground planes is required. 

Figure 4-1: SYM53C875 Pin Diagram 
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The decoupling capacitor arrangement shown above is recommended to maximize the benefits of the internal split ground system. 
Capacitor values between 0.01 and 0. IjiF should provide adequate noise isolation. Because of the number of high current drivers on 
the SYM53C875, a multi-layer PC board with power and ground planes is required. 

Figure 4-2; SYM53C875J Pin Diagram 
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The decoupling capacitor arrangement shown above is recommended to maximize the benefits of the internal split ground system. 
Capacitor values between 0.01 and 0. l\xF should provide adequate noise isolation. Because of the number of high current drivers on 
the SYM53C87S^ a multi-layer PC board with power and ground planes is required. 

Figure 4-3: SYM53C875N Pin Diagram 
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Figure 4-4: SYM53C875JB Pin Diagram (Top View) 
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Note: Pins F7, G6, G7, G8,and H7 are connected to the die pad. 
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Signal Descriptions 

53C875, 53C875J Power and Ground Pins 


The PCI/SCSI pin definitions are organized into the following functional groups: System, Address/Data^ 
Interface Control, Arbitration, Error Reporting, SCSI, and Optional Interface. A slash (/) at the end of 
the signal name indicates that the active state occurs when the signal is at a low voltage. When the slash is 
absent, the signal is active at a high voltage. 

There are four signal type definitions: 

I Input, a standard input-only signal 

O Totem Pole Output, a standard output driver 

T/S Tri-State, a bi-directional, tri-state input/output pin 

S/T/S Sustained Tri-state, an active low tri-state signal owned and driven by one and only one 

agent at a time 


Table 4-1; 53C875, 53C875J Power and Ground Pins 


Symbol 

Pin No. 

Description 

^ss 

4, 10, 14, 18, 23,27, 
31,37,42, 48, 69, 

79, 123, 133, 152, 

158 

Power supplies to the PCI I/O pins 

Vdd 

63,74, 84, 118, 128, 
138 

Power supplies to the PCI I/O pins 

Vdd-i* 

8,21,33,45, 155 

Vdd P^d for PCI bus drivers 

Vss-S 

88, 93, 99, 104, 109, 
114 

Power supplies to the SCSI bus PO pins 

Vss-C 

55, 146 

Power supplies to the internal logic core 


51, 149 

Power supplies to the internal logic core 

^These pins can 

accept aVj)D source of 3.3 or 5 Volts. All other pins must be supplied 5 Volts. 
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53C875N Power and Ground Pins 


Table 4 - 2 : 53C875N Power and Ground Pins 


Symbol 

Pin No. 

Description 

Vss 

10, 16, 20, 24, 29, 

33, 38, 44, 59, 65, 

88, 98, 164, 175, 

196, 202 

Power supplies to the PCI I/O pins 

Vdd 

82, 93, 148, 169, 180 

Power supplies to the PCI I/O pins 

VdD-I* 

14, 27, 62, 199 

Vj)D for PCI bus drivers 

Vss-S 

118, 123, 129, 134, 
139, 144 

Power supplies to the SCSI bus I/O pins 

Vss-C 

72, 189 

Power supplies to the internal logic core 

VdD"C 

68,192 

Power supplies to the internal logic core 


*Thesepins can accept aV^D scmrce of 3.3 or 5 Volts. All otherV^Dpins must be supplied 5 Volts. 


Table 4-3: 53C875JB Power and Ground Pins 


Symbol 

Pin No. 

Description 

Vss 

A9, B3,B11,C3, 
D1,F4, F5, F6, G5, 
H4,J3, K3,K10, 

M4, N2,N9 

Power supplies to the PCI I/O pins 

Vdd 

B10,E8J7,M10 

Power supplies to the PCI I/O pins 

Vdd-i* 

D2, D5,G1J5, K1 

Vdd drivers 

Vss-S 

D12,E13,F12,G11, 

J13,K12 

Power supplies to the SCSI bus I/O pins 

Vdd-S 

C12, Lll 

Power supplies to the SCSI bus I/O pins 

Vss-C 

L6, C6 

Power supplies to the internal logic core 

Vdd-C 

A5, L5 

Power supplies to the internal logic core 

^These pins can 

accept a source of 3.3 or 5 Volts. All otherVj^D pins must be supplied 5 Volts. 
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53C875JB Power and Ground Pins 
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Figure 4-5: SYM53C875 Functional Signal Grouping 


SYM53C875 Data Manual 


4-7 




Signal Descriptions 

System Pins 


Table 4-4: System Pins 


Symbol 

Pin No. 

53C875, 

53C875J/ 

53C875N/ 

53C875JB 

Type 

Description 

CLK 

145/188/A6 

I 

Clock provides timing for all transactions on the PCI bus and is 
an input to every PCI deviceo All other PCI signals are sampled 
on the rising edge of CLK^ and other timing parameters are 
defined with respect to this edgCoThis clock can optionally be 
used as the SCSI core clock; however, the SYM53C875 will not 
be able to achieve fast SCSI transfer rates. 

RST/ 

144/187/B6 

I 

Reset forces the PCI sequencer of each device to a known state. 
All t/s and s/t/s signals are forced to a high impedance state, and 
all internal logic is reset. The RST/ input is synchronized inter¬ 
nally to the rising edge of CLK. The CLK input must be active 
while RST/ is active to properly reset the device. 
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Address and Data Pins 


Table 4-5: Address and Data Pins 


Symbol Pin No. Type 


Description 


AD(31-0) 53C875, T/S 

53C875J: 

150, 151, 

153,154, 

156, 157, 

159, 160,3, 

5, 6, 7, 9, 

11, 12, 13, 

28, 29, 30, 

32, 34, 35, 

36, 38, 40, 
41,43,44, 

46, 47, 49, 

50 

53C875N: 

194, 195, 

197, 198, 

200 , 201 , 

203, 204, 9, 

11, 12, 13, 

15, 17, 18, 
19,35,36, 
37,39,41, 

42, 43, 45, 

48, 58, 60, 

61,63, 64, 

66, 67 

53C875JB: 

B5, C5,A4, 

B4, A3, C4, 
D4,A2, 

C2, E5, Cl, 

D3, E4, E3, 

E2, El, H5, 

J1J2, H6, 
K2J4,L1, 
L2,M1, 

Nl, M3, 

L3, N3, L4, 
K5,N4 


Physical longword address and data are multiplexed on the 
same PCI pins. During the first clock of a transaction, 
AD(31-0) contain a physical address. During subsequent 
clocks, AD(31-0) contain data. A bus transaction consists of 
an address phase, followed by one or more data phases. PCI 
supports both read and write bursts. AD (7-0) define the least 
significant byte, and AD (31-24) define the most significant 
byte. 
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Address and Data Pins 


Table 4-5: Address and Data Pins (Continued) 


Symbol 

Pin No. 

Type 

Description 

C_BE(3-0)/ 

53C875, 
53C875J:1, 
15, 26,39 

53C875N: 
6,21,32,46 

53C875JB: 
A1,F3, H3, 
K4 

T/S 

Bus command and byte enables are multiplexed on the same 
PCI pinSc During the address phase of a transaction^ 
C_BE(3-0)/ define the bus command. During the data phasej 
C_BE(3-0)/ are used as byte enables. The byte enables deter¬ 
mine which b 3 rte lanes carry meaningfiil data. C_BE(0)/ 
applies to byte O 3 and C_BE(3)/ to byte 3, 

PAR 

53C875, 
53C875J: 25 

53C875N: 

31 

53C875JB: 

HI 

T/S 

Parity is the even parity bit that protects the AD (31-0) and 
C_BE(3-0)/ lines. During address phase, both the address 
and command bits are covered. During data phase, both data 
and byte enables are covered. 

BYTEPAR3-0 

(53C875N 

only) 

193, 8 ,34, 

47 

T/S 

When the PCI Byte Parity pins are enabled, the 

SYM53C875N checks each byte of incoming data on the 

PCI bus against its corresponding parity line, in addition to 
the normal parity checking against the PCI PAR signal. This 
extra parity checking/generation is not register selectable; it is 
always enabled for the SYM53C875N. A parity error on any 
Byte Parity pin for PCI master read or slave write operations 
will cause a fatal DMA interrupt; SCRIPTS will stop run¬ 
ning. This interrupt can be masked with the Extended Byte 
Parity Enable bit, bit 1 of the DIEN register. 
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Interface Control Pins 


Table 4-6s Interface Control Pins 


Symbol 

Pin No. 

53C875, 

53C875J/ 

53C875N/ 

53C875JB 

Type 

Description 

FRAME/ 

16/22/F2 

sms 

Cycle Frame is driven by the current master to indicate the begin¬ 
ning and duration of an access. FRAME/ is asserted to indicate a 
bus transaction is beginning. While FRAME/ is asserted^ data trans¬ 
fers continue. When FRAME/ is deasserted^ the transaction is in 
the final data phase or the bus is idle. 

TRDY/ 

19/25/G3 

sms 

Target Ready indicates the target agent’s (selected device’s) ability 
to complete the current data phase of the transaction. TRDY/ is 
used with IRDY/. A data phase is completed on any clock when 
both TRDY/ and IRDY/ are sampled asserted. During a read^ 

TRDY/ indicates that valid data is present on AD (31-0). During a 
writej it indicates the target is prepared to accept data. Wait cycles 
are inserted until both IRDY/ and TRDY/ are asserted together. 

IRDY/ 

17/23/Fl 

sms 

Initiator Ready indicates the initiating agent’s (bus master’s) ability 
to complete the current data phase of the transaction. This signal is 
used with TRDY/. A data phase is completed on any clock when 
both IRDY/ and TRDY/ are sampled asserted. During a write, 

IRDY/ indicates that valid data is present on AD (31-0). During a 
read, it indicates the master is prepared to accept data. Wait cycles 
are inserted until both IRDY/ and TRDY/ are asserted together. 

STOP/ 

22/28/G4 

sms 

Stop indicates that the selected target is requesting the master to 
stop the current transaction. 

DEVSEL/ 

20/26/G2 

sms 

Device Select indicates that the driving device has decoded its 
address as the target of the current access. As an input, it indicates 
to a master whether any device on the bus has been selected. 

IDSEL 

2/7/Bl 

I 

Initialization Device Select is used as a chip select in place of the 
upper 24 address lines during configuration read and write transac¬ 
tions. 
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Arbitration Pins 


/ 

V 


Table 4-7; Arbitration Pins 



Pin No. 
53C875, 



Symbol 

53C875J/ 

53C875N/ 

53C875JB 

Type 

Description 

REQ/ 

148/191/E6 

o 

Request indicates to the arbiter that this agent desires use of the 

PCI bus,This is a point-to-point signal. Every master has its own 
REQ/, 

GNT/ 

147/190/D6 

I 

Grant indicates to the agent that access to the PCI bus has been 
granted. This is a point-to-point signal. Every master has its own 
GNT/. 

Table 4-8: Error Reporting Pins 


Pin No. 
53C875, 



Symbol 

53C875J/ 

53C875N/ 

53C875JB 

Type 

Description 

PERR/ 

24/30/H2 

sms 

Parity Error may be pulsed active by an agent that detects a data 
parity error, PERR/ can be used by any agent to signal data corrup- 
tionSo 

SERR/ 

143/186/E7 

o 

This open drain output pin is used to report address parity errors. 

On detection of a PERR/ pulse^ the central resource may generate a 
non-maskable interrupt to the host CPU^ which often implies the 
system will be unable to continue operation once error processing is 
complete. 
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SCSI Pins 


Table 4-9s SCSI Pins 


Symbol 


SCLK 


SD(15-0)/, 

SDP(l-O)/ 


SCTRiy 


Pin No. 

53C875,53C875J/ t„-- 

53C875N/ 

53C875JB 


56/73/M6 I 


53C875, I/O 

53C875J:113, 

115, 116, 117, 

85, 86, 87, 89, 

102,103,105, 

106, 107, 108, 

110 , 111 , 112 , 

101 

53C875N: 143, 

145, 146, 147, 

115, 116, 117, 

119, 132, 133, 

135, 136, 137, 

138, 140, 141, 

142,131 

53C875JB:D13, 

ElO, C13,D11, 

J9, L13 Kll, 

JIO, GIO, G9, 
F13,F11,F10, 

F9, E12, Ell, 

F8, G13 

53C875, I/O 

53C875J: 92, 90, 
95,91,97, 98, 

100,96, 94 

53C875N: 122, 

120, 125, 121, 

127, 128, 130, 

126, 124 

53C875JB:J12, 
K13,H11, Jll, 

H13, H9,G12, 
H12,H10 


Description 


SCLK is used to derive all SCSI-related timings. The speed of this 
clock is determined by the application’s requirements; in some 
applications SCLK may be sourced internally from the PCI bus 
clock (CLK). If SCLK is internally sourced, then the SCLK pin 
should be tied low. 

SCSI Data includes the following data lines and parity signals: 
SD(15-0)/ (16-bit SCSI data bus), and SDP(l-0)/(SCSI data par¬ 
ity bits). 


SCSI Control includes the following signals: 

SC_D/ SCSI phase line, command/data 

SI_0/ SCSI phase line, input/output 

SMSG/ SCSI phase line, message 

SREQ/ Data handshake signal from tai^et device 

SACK/ Data handshake signal from initiator device 
SBSY/ SCSI bus arbitration signal, busy 
SATN/ SCSI Attention, the initiator is requesting a message 
out phase 

SRST/ SCSI bus reset 

SSEL/ SCSI bus arbitration signal, select device 
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SCSI Pins 


Table 4-9: SCSI Pins (Continued) 


Symbol 


Pin No. 

53C875, S3C875J/ 

53C875N/ 

53C875JB 


Type Description 


SDIR(15-0) 


53C875, 
53C875J: 131, 
132, 134, 135, 
80,81,82, 83, 
120 , 121 , 122 , 
124, 125, 126, 
127, 129 

53C875N; 173, 
174,176,177, 

99, 111, 112, 

113, 150, 162, 
163, 165, 166, 
167,168,170 

53C875JB: C9, 
B9,D8, C8,N12, 
N13,M13,L12, 
B13,A13,A12, 
C11,E9,A11, 
CIO, D9 


O 


Driver direction control for SCSI data lines 


SDIRP(l-O) 

(SDIRPl not 
available on 
53C875J, 
53C875JB) 

130, 119jNA, 
119/171, 149/ 
NA,D10 

O 

Driver direction control for SCSI parity signals In the 
SYM53C875J and SYM53C875JB5 this pin is replaced by the 
TCK JTAG signal. If the device is used in a wide differential sys¬ 
tem, use the SDIRPO pin to control the direction of the differential 
transceiver for both the SPO and SPl signals.The SDIRPO signal is 
capable of drving both direction inputs from a transceiver. 

SELDIR 

76/95/Nll 

O 

Driver enable control for SCSI SEL/ signal 

RSTDIR 

77/96/Ll 0 

o 

Driver enable control for SCSI RST/ signal 

BSYDIR 

78/97/Ml 1 

o 

Driver enable control for SCSI BSY/ signal 

IGS 

75/94/K9 

o 

Direction control for initiator driver group 

TGS 

73/92/NlO 

o 

Direction control for target driver group 
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Table 4-10; Additional Interface Pins 


Symbol 


TESTIN 

(Not avail¬ 
able on 

53C875L 

53C875JB) 


GPIOO_ 

FETCH/ 


GPI01_ 

MASTER/ 


GPI04-3 


Pin No. 

53C875, 53C875J/ 
53C875N/53C875JB 

51, NAI14/NA 


53/70/N5 


54/71/K6 


71,70/90^ 89/L9, 
M9 


Type Description 


I Test In. When this pin is driven low^ the SYM53C875 connects all 
inputs and outputs to an ‘‘AND treCo’^The SCSI control signals 
and data lines are not connected to the “AND tree.’’The output of 
the “AND tree” is connected to the Test Out pin. This allows man¬ 
ufacturers to verify chip connectivity and determine exactly which 
pins are not properly attached. When the TESTIN pin is driven 
low, internal pull-ups are enabled on all inputs output^ and bidirec¬ 
tional pins^ all outputs and bidirectional signals will be tri-stated^ 
and the AiAC/_TESTOUT pin will be enabled. Connectivity can 
be tested by driving one of the SYM53C875 pins low. The MAC/ 
_TESTOUT pin should respond by also driving low. 

I/O General Purpose I/O pin. Optionally, when driven low, indicates 

that the next bus request will be for an op code fetch. This pin pow¬ 
ers up as a general purpose input. 

This pin has two specific purposes in the Symbios SDMS software. 
SDMS uses it to toggle SCSI device LEDs, turning on the LED 
whenever the SYM53C875 is on the SCSI bus. SDMS drives this 
pin low to turn on the LED, or drives it high to turn off the LED. 
This signal can also be used as data I/O for serial EEPROM access. 
In this case it is used with the GPIOO pin, which serves as a clock, 
and the pin can be controlled from PCI configuration register 35h 
or observed from the GPREG operating register, at address 07h. 

I/O General purpose I/O pin. Optionally, when driven low, indicates 
that the SYM53C875 is bus master. This pin powers up as a gen¬ 
eral purpose input. 

Symbios SDMS software supports use of this signal in serial 
EEPROM applications, when enabled, in combination with the 
GPIOO pin. When this signal is used as a clock for serial EEPROM 
access, the GPIO1 pin serves as data, and the pin is controlled 
from PCI configuration register 35h, or observed from the GPREG 
operating register at address 07h. 

I/O General purpose I/O pins. GPI04 powers up as an output. It can 
be used as the enable line forVpp, the 12 Volt power supply to the 
external flash memory interface. GPI03 powers up as an input. 

Symbios SDMS software uses GPI03 to detect a differential 
board. If the pin is pulled low externally, the board will be config¬ 
ured by SDMS as a differential board. If it is pulled high or left 
floating, SDMS will configure it as a single-ended board. The Sym¬ 
bios PCI to SCSI host adapters use the GPI04 pin in the process 
of flashing a new SDMS ROM. 
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Additional Interface Pins 


Table 4-10: Additional Interface Pins (Continued) 


Pin No. 

Symbol 53C875,53C875J/ Type Description 

53C875N/53C875JB 


DIFFSENS 72/91/H8 


MAC/_ 58,NA/76/NA 

TESTOUT 

(Not avail¬ 
able on 
53C875, 

53C875JB) 

IRQ/ 52/69/M5 


BIG.LIT/ 142^ NA/184/NA 

(Not avail¬ 
able on 

53C875L 

53C875JB) 


I The Differential Sense pin detects the presence of a single-ended 

device on a differential system. When external differential trans¬ 
ceivers are used and a zero is detected on this pin^ all chip SCSI 
outputs will be tri-stated to avoid damage to the transceivers. This 
pin should be tied high during single-ended operation.The normal 
value of this pin is 1, 

T/S Memory Access Control. This pin can be programmed to indicate 
local or system memory accesses (non-PCI applications). It is also 
used to test the connectivity of the SYM53C875 signals using an 
‘‘AND tree” scheme. The MAC/_TESTOUT pin is only driven as 
the Test Out function when the TESTIN/ pin is driven low. 


O Interrupt. This signal^ when asserted low^ indicates that an inter¬ 
rupting condition has occurred and that service is required from 
the host CPU. The output drive of this pin is programmed as either 
open drain with an internal weak pull-up or, optionally, as a totem 
pole driver. Refer to the description of DCNTL Register, bit 3, for 
additional information. 

I Big_Little Endian Select. When this pin is driven low, the 

SYM53C875 will route the first byte of an aligned SCSI to PCI 
transfer to byte lane zero of the PCI bus and subsequent b 5 ^es 
received will be routed to ascending lanes. An aligned PCI to SCSI 
transfer will route PCI byte lane zero onto the SCSI bus first, and 
transfer ascending byte lanes in order. When this pin is driven high, 
the SYM53C875 will route the first hyte^ of an aligned SCSI-to- 
PCI transfer to b 5 rte lane three of the PCI bus and subsequent 
bytes received will be routed to descending lanes. An aligned PCI- 
to-SCSI transfer will route PCI byte lane three onto the SCSI bus 
first and transfer descending byte lanes in order. This mode of 
operation also applies to the external memory interface. When this 
pin is driven in Little Endian mode and the chip is performing a 
read from external memory, the byte of data accessed at location 
OOOOOh will be routed to PCI byte lane zero and the data accessed 
at location 00003h will be routed to PCI byte lane three. When the 
chip is performing a write to flash memory, PCI byte lane zero will 
be routed to location OOOOOh and ascending byte lanes will be 
routed to subsequent memory locations. When this pin is driven in 
Big Endian mode and the chip is performing a read from external 
memory, the byte of data accessed at location OOOOOh will be 
routed to PCI byte lane three and the data accessed at location 
00003h will be routed to byte lane zero. When the chip is perform¬ 
ing a write to flash memory, PCI byte lane three will be routed to 
location OOOOOh and descending byte lanes will be routed to subse¬ 
quent memory locations. 
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External Memory Interface Pins 


Table 4-112 External Memory Interface Pins 


Pin No. 


Symbol 


MASO/ 


MASl/ 


MAD7-0 


53C875, 53C875J/ 
53C875N/53C875JB 


137/179/A8 


136/178/B8 


53C875, 

53C875J: 59, 60, 
61,62, 64, 65, 66, 
67 

53C875N: 78, 79, 
80,81,83,84,85, 
86 

53C875JB: L7, 
M7, N7, K7, M8, 
N8, L8, K8 


Type Description 


O Memory Address Strobe 0. This pin is used to latch in the least sig¬ 
nificant address byte of an external EPROM or flash memory. 
Since the SYM53C875 moves addresses eight bits at a time, this 
pin connects to the clock of an external bank of flip-flops which are 
used to assemble up to a 20-bit address for the external memory. 

O Memory Address Strobe 1. This pin is used to latch in the address 
byte corresponding to address bits 15-8 of an external EPROM or 
flash memory. Since the SYM53C875 moves addresses eight bits at 
a time, this pin connects to the clock of an external bank of flip- 
flops which assemble up to a 20-bit address for the external mem¬ 
ory. 

I/O Memory Address/Data Bus. This bus is used in conjunction with 
the memory address strobe pins and external address latches to 
assemble up to a 20-bit address for an external EPROM or flash 
memory. This bus will put out the most significant byte first and 
finish with the least significant bits. It is also used to write data to a 
flash memory or read data into the chip from external EPROM/ 
flash memory. 

The MAD5 pin enables the 4K internal RAM on the 
SYM53C875.To disable the internal RAM, connect a 4.7 
resistor between the MAD5 pin and Connecting a 4.7 KI2 
resistor between the MAD6 pin and¥§§ enables the Subsystem 
Data register in PCI configuration space, a read/write register that 
supports subsystem identification. Connecting a 4.7 KO resistor 
between MAD7 and enables the Serial Control register in PCI 
configuration space, a 2-byte register that controls the GPIOl-0 
pins when serial EEPROM access is enabled. 


MWE/ 

139/181/C7 

O 

Memory Write Enable. This pin is used as a write enable signal to 
an external flash memory. 

MOE/ 

140/182/B7 

O 

Memory Output Enable. This pin is used as an output enable sig¬ 
nal to an external EPROM or flash memory during read opera¬ 
tions. 

MCE/ 

141/183/A7 

o 

Memory Chip Enable. This pin is used as a chip enable signal to an 
external EPROM or flash memory device 

GPI02_ 

MAS2/ 

68 /87/J8 

I/O 

General Purpose I/O pin. Optionally, this pin is used as a Memory 
Address Strobe 2 if an external memory with more than 16 bits of 


addressing is specified by the pull-down resistors at power up and 
bit 0 in the expansion ROM Base Address register is set. 
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Signal Descriptions 

JTAG Pins 53C875J/53C875N/53C875JB Only) 


Table 4-12: JTAG Pins 53C875J/53C875N/53C875JB Only) 


Symbol 

Pin No. 

53C875J/53C875N/ 

53C875JB 

Type Description 


130/172/A10 

Test Clock pin for JTAG boundary scan. 


57/7 5/N6 

Test Mode Select pin for JTAG boundary scan. 


142/185/D7 

Test Data In pin for JTAG boundary scan. 


58/77/J6 

Test Data Out pin for JTAG boundary scan. 
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Operating Registers 


Chapter 5 

Operating Registers 


This section contains descriptions of all 
SYM53C875 operating registers. Table 5-1 sum¬ 
marizes the SYM53C875 operating register set. 
Figure 5-1, the register map, lists registers by oper¬ 
ating and configuration addresses. The terms '"set” 
and ‘‘assert^’ are used to refer to bits that are pro¬ 
grammed to a binary one. Similarly, the terms 
“deassert,” ‘‘clear’^ and ‘‘reset” are used to refer to 
bits that are programmed to a binary zero. Any bits 
marked as reserved should always be written to ze¬ 
ro; mask all information read from them. Reserved 
bit functions may be changed at any time. Unless 
otherwise indicated, all bits in registers are active 
high, that is, the feature is enabled by setting the 


bit. The bottom row of every register diagram 
shows the default register values, which are enabled 
after the chip is powered on or reset. 

Note: the only register that the host CPU can 

access while the SYM53C875 is executing 
SCRIPTS is the ISTAT register; attempts 
to access other registers will interfere with 
the operation of the chip. However, all 
operating registers are accessible with 
SCRIPTS. All read data is synchronized 
and stable when presented to the PCI bus. 

Note: the SYM53C875 cannot fetch SCRIPTS 
instructions from the operating register 
space. Instructions must be fetched from 
system memory or the internal SCRIPTS 
RAM. 


Table 5-1: Operating Register Addresses and Descriptions 


Memoryor I/O 
Address 

Config 

Memory or 1/0 

Read/Write 

Label 

Description 

00 

80 

R/W 

SCNTLO 

SCSI Control 0 

01 

81 

R/W 

SCNTLl 

SCSI Control 1 

02 

82 

R/W 

SCNTL2 

SCSI Control 2 

03 

83 

R/W 

SCNTL3 

SCSI Control 3 

04 

84 

R/W 

SCID 

SCSI Chip ID 

05 

85 

R/W 

SXFER 

SCSI Transfer 

06 

86 

R/W 

SDID 

SCSI Destination ID 

07 

87 

R/W 

GPREG 

General Purpose Bits 

08 

88 

R/W 

SFBR 

SCSI First BytQ Received 

09 

89 

R/W 

SOCL 

SCSI Output Control Latch 

OA 

8A 

R 

SSID 

SCSI Selector ID 

OB 

8B 

R/W 

SBCL 

SCSI Bus Control Lines 

OC 

8C 

R 

DSTAT 

DMA Status 

OD 

8D 

R 

SSTATO 

SCSI Status 0 

OE 

8E 

R 

SSTATl 

SCSI Status 1 

OF 

8F 

R 

SSTAT2 

SCSI Status 2 
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Table 5-1: Operating Register Addresses and Descriptions (Continued) 


Memory 
or I/O 
Address 

Config 
Memory 
or I/O 

Read/Write 

Label 

Description 

10-13 

90-93 

R/W 

DSA 

Data Structure Address 

14 

94 

R/W 

ISTAT 

Interrupt Status 

18 

98 

R/W 

CTESTO 

Reserved 

19 

99 

R/W 

CTESTl 

Chip Test 1 

lA 

9A 

R 

CTEST2 

Chip Test 2 

IB 

9B 

R 

CTEST3 

Chip Test 3 

IC-IF 

9C-9F 


TEMP 

Temporary Register 

20 

AO 

R/W 

DFIFO 

DMA FIFO 

21 

A1 

R/W 

CTEST4 

Chip Test 4 

22 

A2 

R/W 

CTEST5 

Chip Text 5 

23 

A3 

R/W 

CTEST6 

Chip Test 6 

24-26 

A4-A6 

Rm 

DBC 

DMA Byte Counter 

27 

A7 

R/W 

DCMD 

DMA Command 

28-2B 

A8-AB 

R/W 

DNAD 

DMA Next Address for Data 

2C-2F 

AC-AF 

R/W 

DSP 

DMA SCRIPTS Pointer 

30-33 

B0-B3 

R/W 

DSPS 

DMA SCRIPTS Pointer Save 

34-37 

B4-B7 

R/W 

SCRATCHA 

General Purpose Scratch Pad A 

38 

B8 

R/W 

DMODE 

DMA Mode 

39 

B9 

R/W 

DIEN 

DMA Interrupt Enable 

3A 

BA 

R/W 

SBR 

Scratch Byte Register 

3B 

BB 

R/W 

DCNTL 

DMA Control 

3C-3F 

BC-BF 

R 

ADDER 

Sum output of internal adder 

40 

CO 

R/W 

SIENO 

SCSI Interrupt Enable 0 

41 

Cl 

R/W 

SIENl 

SCSI Interrupt Enable 1 

42 

C2 

R 

SISTO 

SCSI Interrupt Status 0 

43 

C3 

R 

SISTl 

SCSI Interrupt Status 1 

44 

C4 

R/W 

SLPAR 

SCSI Longitudinal Parity 

45 

C5 

R 

SWIDE 

SCSI Wide Residue Data 

46 

C6 

RASP' 

MACNTL 

Memory Access Control 

47 

C7 

R/W 

GPCNTL 

General Purpose Control 

48 

C8 

R/W 

STIMEO 

SCSI Timer 0 

49 

C9 

R/W 

STIMEl 

SCSI Timer 1 

4A 

CA 

R/W 

RESPIDO 

Response ID 0 

4B 

CB 

R/W 

RESPIDl 

Response ID 1 
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Table 5-1: Operating Register Addresses and Descriptions (Continued) 


Memory 
or I/O 
Address 

Config 
Memory 
or I/O 

Read/Write 

Label 

Description 

4C 

CC 

R 

STESTO 

SCSI Test 0 

4D 

CD 

R 

STESTl 

SCSI Test 1 

4E 

CE 

Rm 

STEST2 

SCSI Test 2 

4F 

CF 

R/W 

STEST3 

SCSI Test 3 

50-51 

DO-Dl 

R 

SIDE 

SCSI Input Data Latch 

52-53 

D2-D3 


Reserved 


54-55 

D4-D5 

R/W 

SODL 

SCSI Output Data Latch 

56-57 

D6-D7 


Reserved 


58-59 

D8-D9 

R 

SBDL 

SCSI Bus Data Lines 

5A-5B 

DA-DB 


Reserved 


5C-5F 

DC-DF 

R/W 

SCRATCHB 

General Purpose Scratch Pad B 

60-7F 

EO-FF 

R/W 

SCRATCHC-J 

General Purpose Scratch Pad C-J 
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Mem I/O 

Config 

SCNTL3 

SCNTL2 

SCNTLl 

SCNTLO 

00 

80 

GPREG 

SDID 

SXFER 

SCID 

04 

84 

SBCL 

SSID 

SOCL 

SFBR 

08 

88 

SSTAT2 

SSTATl 

SSTATO 

DSTAT 

oc 

8C 

DSA 

10 

90 

RESERVED 

ISTAT 

14 

94 

CTEST3 

CTEST2 

CTESTl 

RESERVED 

18 

98 

TEMP 

1C 

9C 

CTEST6 

CTEST5 

CTEST4 

DFIFO 

20 

AO 

DCMD 

DEC 

24 

A4 

DNAD 

28 

A8 

DSP 

2C 

AC 

DSPS 

30 

BO 

SCRATCHA 

34 

B4 

DCNTL 

SBR 

DIEN 

DMODE 

38 

B8 

AD] 

DER 

3C 

BC 

SISTl 

SISTO 

SIENl 

SIENO 

40 

CO 

GPCNTL 

MACNTL 

SWIDE 

SLPAR 

44 

C4 

RESPIDl 

RESPIDO 

STIMEl 

STIMEO 

48 

C8 

STEST3 

STEST2 

STESTl 

STESTO 

4C 

CC 

RESERVED 

SIDE 

50 

DO 

RESERVED 

SODL 

54 

D4 

RESERVED 

SBDL 

58 

D8 

SCRATCH B 

5C 

DC 

SCRATCHC 

60 

EO 

SCRATCHD 

64 

E4 

SCRATCHE 

68 

E8 

SCRATCHF 

6C 

EC 

SCRATCHG 

70 

FO 

SCRATCHH 

74 

F4 

SCRATCHI 

78 

F8 

SCRATCH! 

7F 

FF 


Figure 5-1: SYM53C875 Register Address Map 


5-4 


SYM53C875 Data Manual 





















































































































Operating Registers 


Register 00 (80) 

SCSI Control Zero (SCNTLO) 
ReadA5(^rite 


ARB1 

ARBO 

START 

WATN 

EPC 

RES 

AAP 

TRG I 

7 

6 

5 

4 

3 

2 

1 

0 I 

Default»> 

1 1 

0 

0 

0 

X 

0 

0 


Bit 7 ARBI (Arbitration Mode bit 1) 
Bit 6 ARBO (Arbitration Mode bit 0) 


ARB1 

ARBO 

Arbitration Mode 

0 

0 

Simple arbitration 

0 

1 

Reserved 

1 

0 

Reserved 

1 

1 

Full arbitration, selection/reselection 


Simple Arbitration 

L The SYM53C875 waits for a bus free 
condition to occur. 

2. It asserts SBSY/ and its SCSI ID 
(contained in the SCID register) onto the 
SCSI bus. If the SSEIV signal is asserted by 
another SCSI device, the SYM53C875 will 
deassert SBSY/, deassert its ID and set the 
Lost Arbitration bit (bit 3) in the SSTATO 
register. 

3. After an arbitration delay, the CPU should 
read the SBDL register to check if a higher 
priority SCSI ID is present. If no higher 
priority ID bit is set, and the Lost 
Arbitration bit is not set, the SYM53C875 
has won arbitration. 

4. Once the SYM53C875 has won 
arbitration, SSEL/ must be asserted via the 
SOCL for a bus clear plus a bus settle delay 
(1.2 lus) before a low level selection can be 
performed. 


Full Arbitration, Selection/Reselection 

lo The SYM53C875 waits for a bus free 
condition. 

2. It asserts SBSY/ and its SCSI ID (the 
highest priority ID stored in the SCID 
register) onto the SCSI bus. 

3. If the SSEL/ signal is asserted by another 
SCSI device or if the SYM53C875 detects 
a higher priority ID, the SYM53C875 will 
deassert BSY, deassert its ID, and wait 
until the next bus free state to try 
arbitration again. 

4. The SYM53C875 repeats arbitration until 
it wins control of the SCSI bus. When it 
has won, the Won Arbitration bit is set in 
the SSTATO register, bit 2. 

5. The SYM53C875 performs selection by 
asserting the following onto the SCSI bus: 
SSEL/, the target's ID (stored in the SDID 
register), and the SYM53C875's ID 
(stored in the SCID register). 

6o After a selection is complete, the Function 
Complete bit is set in the SISTO register, 
bit 6. 

7. If a selection time-out occurs, the Selection 
Time-Out bit is set in the SISTl register, 
bit 2. 

Bit 5 START (Start Sequence) 

When this bit is set, the 
SYM53C875 will start the arbitration 
sequence indicated by the Arbitration Mode 
bits. The Start Sequence bit is accessed directly 
in low-level mode; during SCSI SCRIPTS 
operations, this bit is controlled by the 
SCRIPTS processor. An arbitration sequence 
should not be started if the connected (CON) 
bit in the SCNTLI register, bit 4, indicates 
that the SYM53C875 is already connected to 
the SCSI bus. This bit is automatically cleared 
when the arbitration sequence is complete. If a 
sequence is aborted, bit 4 in the SCNTLI reg¬ 
ister should be checked to verify that the 
SYM53C875 did not connect to the SCSI bus. 
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Bit 4 WATN (Select with SATN/ on a Start 
Sequence) 

When this bit is set and the SYM53C875 is in 
initiator mode, the SATN/ signal will be 
asserted during SYM53C875 selection of a 
SCSI target device. This is to inform the target 
that the SYM53C875 has a message to send. If 
a selection time-out occurs while attempting to 
select a target device, SATN/will be deasserted 
at the same time SSEIV is deasserted. When 
this bit is clear, the SATN/ signal will not be 
asserted during selection. When executing 
SCSI SCRIPTS, this bit is controlled by the 
SCRIPTS processor, but it may be set manu¬ 
ally in low level mode. 

Bit 3 EPC (Enable Parity Checking) 

When this bit is set, the SCSI data bus is 
checked for odd parity when data is received 
from the SCSI bus in either initiator or target 
mode. Parity is also checked as data goes from 
the SCSI FIFO to the DMA FIFO. If a parity 
error is detected, bit 0 of the SISTO register is 
set and an interrupt may be generated. 

If the SYM53C875 is operating in initiator 
mode and a parity error is detected, SATN/ 
can optionally be asserted, but the transfer 
continues until the target changes phase. When 
this bit is cleared, parity errors are not 
reported. 

When these bits are set in the SYM53C875N, 
the chip again checks inbound SCSI parity at 
the SCSI FIFO—DMA FIFO interface after 
the data has passed through the SCSI FIFO. 
The parity bits are not passed through the 
DAIA FIFO, but parity is generated before the 
data is sent out on the PCI bus. 

Bit 2 Reserved 

Bit 1 AAP (Assert SATN/ on Parity Error) 

When this bit is set, the SYM53C875 automat¬ 
ically asserts the SATN/ signal upon detection 
of a parity error. SATN/ is only asserted in ini¬ 
tiator mode. The SATN/ signal is asserted 
before deasserting SACK/ during the byte 


transfer with the parity error. The Enable Par¬ 
ity Checking bit must also be set for the 
SYM53C875 to assert SATN/ in this manner. 
A parity error is detected on data received from 
the SCSI bus. 

If the Assert SATN/ on Parity Error bit is 
cleared or the Enable Parity Checking bit is 
cleared, SATN/ will not be automatically 
asserted on the SCSI bus when a parity error is 
received. 

Bit 0 TRG (Target Mode) 

This bit determines the default operating mode 
of the SYM53C875.The user must manually 
set target or initiator mode. This can be done 
using the SCRIPTS language (SETTARGET 
or CLEAR TARGET). When this bit is set, the 
chip is a target device by default. When this bit 
is cleared, the SYM53C875 is an initiator 
device by default. 

CAUTION^ 

Writing this bit while not connected may cause the 
loss of a selection or reselection due to the chang¬ 
ing of target or initiator modes. 
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Register 01 (81) 

SCSI Control One (SCNTLl) 
Read/Write 


m 

X 

o 

ADB 

DHP 

CON 

RST 

AESP 

lARB 1 

SST 

7 

6 

5 

4 

3 

2 

1 I 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 EXC (Extra Clock Cycle of Data 
Setup) 

When this bit is set, an extra clock period of 
data setup is added to each SCSI send data 
transfer. The extra data setup time can provide 
additional system design margin, though it will 
affect the SCSI transfer rates. Clearing this bit 
disables the extra clock cycle of data setup 
time. Setting this bit only affects SCSI send 
operations. 

Bit 6 ADB (Assert SCSI Data Bus) 

When this bit is set, the 
SYM53C875 drives the contents of the SCSI 
Output Data Latch Register (SODL) onto the 
SCSI data bus.When the SYM53C875 is an 
initiator, the SCSI I/O signal must be inactive 
to assert the SODL contents onto the SCSI 
bus. When the SYM53C875 is a target, the 
SCSI I/O signal must be active for the SODL 
contents to be asserted onto the SCSI bus.The 
contents of the SODL register can be asserted 
at any time, even before the SYM53C875 is 
connected to the SCSI bus.This bit should be 
cleared when executing SCSI SCRIPTS. It is 
normally used only for diagnostics testing or 
operation in low level mode. 

Bit 5 DHP (Disable Halt on Parity Error 
or ATN) (Target Only) 

The DHP bit is only defined for target mode. 
When this bit is cleared, the SYM53C875 halts 
the SCSI data transfer when a parity error is 
detected or when the SATN/ signal is asserted. 
If SATN/ or a parity error is received in the 
middle of a data transfer, the SYM53C875 
may transfer up to three additional bytes before 
halting to synchronize between internal core 


cells. During synchronous operation, the 
SYM53C875 transfers data until there are no 
outstanding synchronous offsets. If the 
SYM53C875 is receiving data, any data resid¬ 
ing in the DMA FIFO is sent to memory 
before halting. 

When this bit is set, the SYM53C875 does not 
halt the SCSI transfer when SATN/ or a parity 
error is received. 

Bit 4 CON (Connected) 

This bit is automatically set any time the 
SYM53C875 is connected to the SCSI bus as 
an initiator or as a target. It is set after the 
SYM53C875 successfully completes arbitra¬ 
tion or when it has responded to a bus initiated 
selection or reselection. This bit is also set after 
the chip wins simple arbitration when operat¬ 
ing in low level mode. When this bit is clear, 
the SYM53C875 is not connected to the SCSI 
bus. 

The CPU can force a connected or discon¬ 
nected condition by setting or clearing this bit. 
This feature would be used primarily during 
loopback mode. 

Bit 3 RST (Assert SCSI RST/ Signal) 

Setting this bit asserts the SRST/ signal. The 
SRST/ output remains asserted until this bit is 
cleared. The 25 jis minimum assertion time 
defined in the SCSI specification must be 
timed out by the controlling microprocessor or 
a SCRIPTS loop. 

Bit 2 AESP (Assert Even SCSI Parity 
(force bad parity)) 

When this bit is set, the 
SYM53C875 asserts even parity. It forces a 
SCSI parity error on each byte sent to the 
SCSI bus firom the SYM53C875. If parity 
checking is enabled, then the SYM53C875 
checks data received for odd parity. This bit is 
used for diagnostic testing and should be clear 
for normal operation. It can be used to gener¬ 
ate parity errors to test error handling func¬ 
tions. 
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Bit 1 lARB (Immediate Arbitration) 

Setting this bit causes the SCSI core to imme¬ 
diately begin arbitration once a Bus Free phase 
is detected following an expected SCSI discon¬ 
nect. This bit is useful for multi-threaded appli¬ 
cations. The ARB 1-0 bits in SCNTLO should 
be set for fiill arbitration and selection before 
setting this bit. 

Arbitration will be re-tried until won. At that 
point, the SYM53C875 will hold BSY and 
SEL asserted, and wait for a select or reselect 
sequence to be requested. The Immediate 
Arbitration bit will be reset automatically when 
the selection or reselection sequence is com¬ 
pleted, or times out. 

An unexpected disconnect condition will clear 
lARB without attempting arbitration. See the 
SCSI Disconnect Unexpected bit (SCNTL2, 
bit 7) for more information on expected versus 
unexpected disconnects. 

An immediate arbitration sequence can be 
aborted. First, the Abort bit in the ISTAT reg¬ 
ister should be set. Then one of two things will 
eventually happen: 

1 o The Won Arbitration bit (SSTATO bit 2) 
will be set. In this case, the Immediate 
Arbitration bit needs to be reset. This will 
complete the abort sequence and 
disconnect the SYM53C875 from the 
SCSI bus. If it is not acceptable to go to 
Bus Free phase immediately following the 
arbitration phase, a low level selection may 
be performed instead. 

2. The abort will complete because the 

SYM53C875 loses arbitration. This can be 
detected by the Immediate Arbitration bit 
being cleared. The Lost Arbitration bit 
(SSTATO bit 3) should not be used to 
detect this condition. No further action 
needs to be taken in this case. 


Bit 0 SST (Start SCSI Transfer) 

This bit is automatically set during SCRIPTS 
execution, and should not be used. It causes 
the SCSI core to begin a SCSI transfer, includ¬ 
ing SREQ/SACK handshaking. The determi¬ 
nation of whether the transfer is a send or 
receive is made according to the value written 
to the FO bit in SO CL. This bit is self-reset- 
ting. It should not be set for low level opera¬ 
tion. 

CAUTION: 

Writing to this register while not connected may 
cause the loss of a selection/reselection by resetting 
the Connected bit. 
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Register 02 (82) 

SCSI Control Two (SCNTL2) 
Read/Write 


SDU 

CHM 

SLPMD 

SLPHBEN 

WSS 

VUEO 

VUE1 

WSR 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 SDU (SCSI Disconnect Unexpected) 

This bit is valid in initiator mode only. When 
this bit is set, the SCSI core is not expecting 
the SCSI bus to enter the Bus Free phase. If it 
does, an unexpected disconnect error will be 
generated (see the Unexpected Disconnect bit 
in the SISTO register, bit 2). During normal 
SCRIPTS mode operation, this bit is set auto¬ 
matically whenever the SCSI core is reselected, 
or successfully selects another SCSI device. 
The SDU bit should be reset with a register 
write (MOVE 0X00 TO SCNTL2) before the 
SCSI core expects a disconnect to occur, nor¬ 
mally prior to sending an Abort, Abort Tag, 

Bus Device Reset, Clear Queue or Release 
Recovery message, or before deasserting 
SACK/ after receiving a Disconnect command 
or Command Complete message. 

Bit 6 CHM (Chained Mode) 

This bit determines whether or not the SCSI 
core is programmed for chained SCSI mode. 
This bit is automatically set by the Chained 
Block Move (CHMOV) SCRIPTS instruction 
and is automatically cleared by the Block Move 
SCRIPTS instruction (MOVE). 

Chained mode is primarily used to transfer 
consecutive wide data blocks. Using chained 
mode facilitates partial receive transfers and 
allows correct partial send behavior. When this 
bit is set and a data transfer ends on an odd 
b 5 ^e boundary, the SYM53C875 will store the 
last byte in the SCSI Wide Residue Data Regis¬ 
ter during a receive operation, or in the SCSI 
Output Data Latch register during a send 
operation. This byte will be combined with the 
first b 5 ^e from the subsequent transfer so that a 
wide transfer can be completed. 


For more information, see the Chained 
Mode^’ section in Chapter 2, "functional 
Description.” 

Bit 5 SLPMD (SLPAR Mode Bit) 

If this bit is clear, the SLPAR register fiinctions 
like the SYM53C825. If this bit is set, the 
SLPAR register reflects the high or low byte of 
the SLPAR word, depending on the state of 
SCNTL2 bit 4. It also allows a seed value to be 
written to the SLPAR register. 

Bit 4 SLPHBEN (SLPAR High Byte 
Enable) 

If this bit is clear, the low byte of the SLPAR 
word is present in the SLPAR register. If this 
bit is set, the high byte of the SLPAR word is 
present in the SLPAR register. 

Bit 3 WSS (Wide SCSI Send) 

When read, this bit returns the value of the 
Wide SCSI Send (WSS) flag. Asserting this bit 
will clear the WSS flag. This clearing function 
is self-resetting. 

When the WSS flag is high following a wide 
SCSI send operation, the SCSI core is holding 
a byte of ""chain” data in the SODL register. 
This data will become the first low-order hytt 
sent when married with a high-order byte dur¬ 
ing a subsequent data send transfer. 

Performing a SCSI receive operation will clear 
this bit. Also, performing any non-wide trans¬ 
fer will clear this bit. 

Bit 2 VUEO (Vendor Unique Enhance¬ 
ments bit 0) 

This bit is a read only value indicating whether 
the group code field in the SCSI instruction is 
standard or vendor unique. If reset, the bit 
indicates standard group codes; if set, the bit 
indicates vendor unique group codes. The 
value in this bit is reloaded at the beginning of 
all asynchronous target receives. The default 
for this bit is reset. 
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Bit 1 VUEl (Vendor Unique Enhance¬ 
ments bit 1) 

This bit is used to disable the automatic b5rte 
count reload during Block Move instructions 
in the command phase. If this bit is reset, the 
device will reload the Block Move byte count if 
the first byte received is one of the standard 
group codes. If this bit is set, the device will 
not reload the Block Move byte count, regard¬ 
less of the group code. 

Bit 0 WSR (Wide SCSI Receive) 

When read, this bit returns the value of the 
Wide SCSI Receive (WSR) flag. Setting this 
bit clears the WSR flag. This clearing function 
is self-resetting. 

The WSR flag indicates that the SCSI core 
received data from the SCSI bus, detected a 
possible partial transfer at the end of a chained 
or non-chained block move command, and 
temporarily stored the high-order byte in the 
SWIDE register rather than passing the byte 
out the DMA channel.The hardware uses the 
WSR status flag to determine what behavior 
must occur at the start of the next data receive 
transfer. When the flag is set, the stored data in 
SWIDE may be “residue” data, valid data for a 
subsequent data transfer, or overrun data. The 
byte may be read as normal data by starting a 
data receive transfer. 

Performing a SCSI send operation will clear 
this bit. Also, performing any non-wide trans¬ 
fer will clear this bit. 


Register 03 (83) 

SCSI Control Three (SCNTL3) 
Read/Write 


F20 

SCF2 

SCF1 

SCFO 

EWS 

CCF2 

CCF1 

CCFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 F20 (Fast-20 Enable) 

Setting this bit enables UltraSCSI s 5 mchronous 
SCSI transfers in systems that have an 80 MHz 
clock. The default value of this bit is O.This bit 
should remain cleared in systems that have a 
40MHz clock, unless the SCSI clock doubler is 
used to increase the SCLK firequency to at 
least 80 MHz. 

When this bit is set, the signal filtering period 
for SREQ/ and SACK/ automatically changes 
to 15 ns, regardless of the value of the Extend 
REQ/ACK Filtering bit in the STEST2 regis¬ 
ter. 

Bits 6-4 SCF2-0 ( Synchronous Clock 
Conversion Factor) 

These bits select a factor by which the fire¬ 
quency of SCLK is divided before being pre¬ 
sented to the synchronous SCSI control logic. 
They should be written to the same value as 
the Clock Conversion Factor bits below unless 
fast SCSI operation is desired. See the SCSI 
Transfer (SXFER) register description for 
examples of how the SCF bits are used to cal¬ 
culate sjmchronous transfer periods. See the 
table under the description of bits 7-5 of the 
SXFER register for the valid combinations. 

Note: to migrate firom a Fast SCSI-2 system with 
a 40MHz clock, divide the clock by a factor 
of two or more to achieve the same 
synchronous transfer rate in a system with 
an 80MHz clock. 

Note: for additional information on how the 

synchronous transfer rate is determined, 
refer to Chapter 2. 
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Bit 3 EWS (Enable Wide SCSI) 

When this bit is clear, all information transfer 
phases are assumed to be eight bits, transmit¬ 
ted on SD7-0/, SDPO/. When this bit is 
asserted, data transfers are done 16 bits at a 
time, with the least significant byte on SD7-0/, 
SDP/ and the most significant byte on 
SD15--8/, SDPl/o Command, Status, and Mes¬ 
sage phases are not affected by this bit. 

Clearing this bit will also clear the Wide SCSI 
Receive bit in the SWIDE register. 


Bits 2-0 CCF2-0 (Clock Conversion Factor) 

These bits select a factor by which the fre¬ 
quency of SCLK is divided before being pre¬ 
sented to the SCSI core. The synchronous 
portion of the SCSI core can be run at a differ¬ 
ent clock rate for fast SCSI, using the Synchro¬ 
nous Clock Conversion Factor bits. The bit 
encoding is displayed in the table below. All 
other combinations are reserved and should 
never be used. 


SCF2 

CCF2 

SCF1 

CCF1 

SCFO 

CCFO 

Factor 

Frequency 

SCSI Clock 
(MHz) 

0 

0 

0 

SCLK/3 

50.01-75 

0 

0 

1 

SCLK/1 

16.67-25 

0 

1 

0 

SCLK/1.5 

25.01-37.5 

0 

1 

1 

SCLK/2 

37.51-50 

1 

0 

0 

SCLK/3 

50.01-75 

1 

0 

1 

SCLK/4 

75.01-80.00 

1 

1 

0 

Reserved 


1 

1 

1 

Reserved 



Note: it is important that these bits be set to the 
proper values to guarantee that the 
SYM53C875 meets the SCSI timings as 
defined by the ANSI specification. 

Note: for additional information on how the 

synchronous transfer rate is determined, 
refer to Chapter 2, ‘‘Functional 
Description.^^ 

Note: to migrate from a Fast SCSI-2 system with 
a 40MHz clock, divide the clock by a factor 
of two or more to achieve the same 
synchronous transfer rate in a system with 
an 80MHz clock. 

Note: if the SCSI clock doubler is enabled, use 
the desired frequency after doubling to 
determine the conversion factor. 
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Register 04 (84) 

SCSI Chip ID (SCID) 
Read/Write 



■jnn 


RES 

ENC3 

ENC2 

ENC1 

ENCO 

nn 

■I 

■I 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

X 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 RRE (Enable Response to 

Reselection) 

When this bit is set, the SYM53C875 is 
enabled to respond to bus-initiated reselection 
at the chip ID in the RESPIDO and RESPIDl 
registers. Note that the SYM53C875 will not 
automatically reconfigure itself to initiator 
mode as a result of being reselected. 

Bit 5 SRE (Enable Response to Selection) 

When this bit is set, the SYM53C875 is able to 
respond to bus-initiated selection at the chip 
ID in the RESPIDO and RESPIDl registers. 
Note that the SYM53C875 will not automati¬ 
cally reconfigure itself to target mode as a 
result of being selected. 

Bit 4 Reserved 


Register 05 (85) 

SCSI Transfer (SXFER) 
Read/Write 


TP2 

TP1 

TPO 

M04 

M03 


M01 


7 

6 

5 

4 

3 

■n 

1 

mu 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Note: when using Table Indirect I/O commands, 
bits 7-0 of this register will be loaded firom 
the I/O data structure. 


Note: for additional information on how the 

synchronous transfer rate is determined, 
refer to Chapter 2, “Functional 
Description.” 

Bits 7-5 TP2-0 (SCSI Synchronous Transfer 
Period) 

These bits determine the SCSI s 5 mchronous 
transfer period used by the SYM53C875 when 
sending sjmchronous SCSI data in either initia¬ 
tor or target mode. These bits control the pro¬ 
grammable dividers in the chip. 

Note: for UltraSCSI transfers, the ideal transfer 
period is 4, and 5 is acceptable. Setting the 
transfer period to a value greater than 5 is 
not recommended. 


Bits 3-0 Encoded Chip SCSI ID, bits 3-0 

These bits are used to store the SYM53C875 
encoded SCSI ID. This is the ID which the 
chip will assert when arbitrating for the SCSI 
bus. The IDs that the SYM53C875 will 
respond to when being selected or reselected 
are configured in the RESPIDO and RESPIDl 
registers. The priority of the 16 possible IDs, in 
descending order is: 

Highest Lowest 

7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 


TP2 

TP1 

TPO 

XFERP 

0 

0 

0 

4 

0 

0 

1 

5 

0 

1 

0 

6 

0 

1 

1 

7 

1 

0 

0 

8 

1 

0 

1 

9 

1 

1 

0 

10 

1 

1 

1 

11 
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The synchronous transfer period the 
SYM53C875 should use when transferring 
SCSI data is determined as in this exam- 
ple.The SYM53C875 is connected to a hard 
disk which can transfer data at 10 MB/s syn¬ 
chronously. The SYM53C875’s SCLK is run¬ 
ning at 40 MHz. The synchronous transfer 
period (SXFERP) is found as follows: 

SXFERP=Period/SSCP + ExtCC 
Period = 1 + Frequency =1+10 MB/s = 100 ns 
SSCP = 1 +SSCF = 1 + 40 MHz = 25 ns 
(This SCSI synchronous core clock is determined in SCNTL3 bits 6-4 
ExtCC = 1 if SCNTL1 bit 7 is asserted and the SYM53C875 is sending data. 

ExtCC = 0 if the SYM53C875 is receiving data) 

SXFERP = 100+ 25 = 4 
Key: 

SXFERP = Synchronous transfer period 
SSCP = SCSI Synchronous core period 
SSCF = SCSI Synchronous core frequency 
ExtCC = Extra clock cycle of data setup 


Table 5-2: Examples of Synchronous Transfer 
Periods for SCSI-1 Transfer Rates 


CLK 

(MHz) 

SCSI CLK 

SCNTL3 
bits 6-4 

XFERP 

Synch. 

Transfer 

Period 

(ns) 

Synch. 

Send 

Rate 

(MB/s) 

Synch. 

Receive 

Rate 

(MB^) 

80 

-^4 

4 

200 

5 

5 

80 

-4 

5 

250 

4 

5 

66.6 

7 

-3 

4 

180 

5.55 

5.55 

66.6 

7 

-3 

5 

225 

4.44 

5.55 

50 

-2 

4 

160 

6.25 

6.25 

50 

-2 

5 

200 

5 

6.25 

40 

■^2 

4 

200 

5 

5 

37.5 

0 

^1.5 

4 

160 

6.25 

6.25 

33.3 

3 

-1.5 

4 

180 

5.55 

5.55 
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Table 5-2: Examples of Synchronous Transfer 
Periods for SCSI-1 Transfer Rates 


CLK 

(MHz) 

SCSI CLK 

-5- 

SCNTL3 
bits 6-4 

XFERP 

Synch. 

Transfer 

Period 

(ns) 

Synch. 

Send 

Rate 

(MB^) 

Synch. 

Receive 

Rate 

(MB/s) 

25 

-^l 

4 

160 

6.25 

6.25 

20 

■^1 

4 

200 

5 

5 

16.6 

7 

-1 

4 

240 

4.17 

4.17 


Table 5-3: Example Transfer periods for fast 
SCSI-2 and Fast-20 transfer rates 


SCSI 


Synch. 

Synch. 

Sync. 

CLK 

CLK^ 

XFER 

Transfer 

Send 

Receive 

(MHz) 

SCNTL3 

P 

Period 

Rate 

Rate 


bits 6-4 


(ns) 

(MB/s) 

(MB^) 

80 

- 1 

4 

50 

20.0 

20.0 

80 

-2 

4 

100 

10.0 

10.0 

66.67 

-1-1.5 

4 

90 

11.11 

11.11 

66.67 

-hi.5 

5 

112.5 

8.88 

11.11 

50 

-1 

4 

80 

12.5 

12.5 

50 

-1 

5 

100 

10.0 

12.5 

40 

-1 

4 

100 

10.0 

10.0 

37.50 

-1 

4 

106.67 

9.375 

9.375 

33.33 

-5-1 

4 

120 

8.33 

8.33 

25 

-5-1 

4 

160 

6.25 

6.25 

20 

-1 

4 

200 

5 

5 

16.67 

-1 

4 

240 

4.17 

4.17 
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Bits 4-0 MO4-MO0 (Max SCSI Synchronous 
Offset) 

These bits describe the maximum SCSI syn¬ 
chronous offset used by the SYM53C875 
when transferring synchronous SCSI data in 
either initiator or target mode. The following 
table describes the possible combinations and 
their relationship to the sjmchronous data off¬ 
set used by the SYM53C875.These bits deter¬ 
mine the SYM53C875’s method of transfer for 
Data In and Data Out phases only; all other 
information transfers will occur asynchro¬ 
nously. 


M04 

M03 

M02 

M01 

MOO 

Synchronous 

Offset 

0 

0 

0 

0 

0 

0-Asynchronous 

0 

0 

0 

0 

1 

1 

0 

0 

0 

1 

0 

2 

0 

0 

0 

1 

1 

3 

0 

0 

1 

0 

0 

4 

0 

0 

1 

0 

1 

5 

0 

0 

1 

1 

0 

6 

0 

0 

1 

1 

1 

7 

0 

1 

0 

0 

0 

8 

0 

1 

0 

0 

1 

9 

0 

1 

0 

1 

0 

10 

0 

1 

0 

1 

1 

11 

0 

1 

1 

0 

0 

12 

0 

1 

1 

0 

1 

13 

0 

1 

1 

1 

0 

14 

0 

1 

1 

1 

1 

15 

1 

0 

0 

0 

0 

16 

1 

X 

X 

X 

1 

Reserved 

1 

X 

X 

1 

X 

Reserved 

1 

X 

1 

X 

X 

Reserved 

1 

1 

X 

X 

X 

Reserved 


Register 06 (86) 

SCSI Destination ID (SDID) 
Read/Write 


RES 

RES 

RES 

RES 

ENC3 

ENC2 

ENC1 

ENCO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

X 

X 

0 

0 

0 

0 


Bits 7-4 Reserved 

Bits 3-0 Encoded Destination SCSI ID 

Writing these bits sets the SCSI ID of the 
intended initiator or target during SCSI rese¬ 
lection or selection phases, respectively. When 
executing SCRIPTS, the SCRIPTS processor 
writes the destination SCSI ID to this register. 
The SCSI ID is defined by the user in a 
SCRIPTS SELECT or RESELECT instruc¬ 
tion. The value written should be the binary- 
encoded ID value. The priority of the 16 possi¬ 
ble IDs, in descending order, is; 

Highest Lowest 

7 6 5 4 3 2 1 0 15 14 13 12 11 0 9 8 
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Register 07 (87) 

General Purpose (GPREG) 
Read/Write 


RES 

RES 

RES 

GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

X 

0 

X 

X 

X 

X 


SDMS uses the GPIOl-0 pins to support 
serial EEPROM access« When serial EEPROM 
acccess is enabled, GPIOl is used as a clock 
and GPIOO is used as dataoThe pins are con¬ 
trolled from PCI configuration register 35h. 
They may be read, but not controlled, from 
this register. 


Bits 7-5 Reserved 

Bits 4-0 GPIO4-GPIO0 (General Purpose) 

These bits can be programmed through the 
GPCNTL Register to become inputs, outputs 
or to perform special functions. As an output, 
these pins can be used to enable or disable 
external terminators. These signals can also be 
programmed as live inputs and sensed through 
a SCRIPTS Register to Register Move Instruc¬ 
tion. GPIO(3-0) default as inputs and GPI04 
defaults as an output pin. When configured as 
inputs, an internal pull-up is enabled. 

GPI04 can be used to enable or disable Vpp, 
the 12-volt power supply to the external flash 
memory. This bit powers up with the power to 
the external memory disabled. 

The GPIOl-0 signals can also be controlled 
from PCI configuration register 35h.They may 
be read, but not controlled, from this register. 

SDMS Use of GPIO Pins 

Symbios Logic SDMS software uses GPI03 to 
detect a differential board. If the pin is pulled 
low externally, the board will be configured by 
SDMS as a differential board. If it is pulled 
high or left floating, SDMS will configure it as 
a single-ended board. The Sjrmbios PCI to 
SCSI host adapters use the GPI04 pin in the 
process of flashing a new SDMS ROM. 

Symbios SDMS software uses the GPIOO pin 
to toggle SCSI device LEDs, turning on the 
LED whenever the SYM53C875 is on the 
SCSI bus. SDMS drives this pin low to turn on 
the LED, or drives it high to turn off the LED. 
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Register 08 (88) 

SCSI First Byte Received (SFBR) 
Read/Write 


■a 

1B6 

1B5 




1B1 

1B0 

■1 

6 

5 

■1 

■1 

m 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


This register contains the first byte received in any 
asynchronous information transfer phase. For ex¬ 
ample, when the SYM53C875 is operating in initi¬ 
ator mode, this register contains the first byte 
received in the Message In, Status, and Data In 
phases. 

When a Block Move instruction is executed for a 
particular phase, the first b 3 ^e received is stored in 
this register— even if the present phase is the same 
as the last phase. The first byte received value for a 
particular input phase is not valid until after a 
MOVE instruction is executed. 

This register is also the accumulator for register 
read-modify-writes with the SFBR as the destina¬ 
tion. This allows bit testing after an operation. 

The SFBR is not writable via the CPU, and there¬ 
fore not by a Memory Move. The Load instruction 
may not be used to write to this register.However, 
it can be loaded via SCRIPTS Read/Write opera¬ 
tions. To load the SFBR with a bjrte stored in sys¬ 
tem memory, the byte must first be moved to an 
intermediate SYM53C875 register (such as the 
SCRATCH register), and then to the SFBR. 

This register will also contain the state of the lower 
eight bits of the SCSI data bus during the selection 
phase if the COM bit in the DCNTL register is 
clear. 


Register 09 (89) 

SCSI Output Control Latch (SOCL) 
Read /Write 


REQ 


BSY 

SEL 



C/D 

I/O 

7 

m 

5 

4 

■■ 

mu 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 REQ(Assert SCSI REQ/ Signal) 

Bit 6 ACK(Assert SCSI ACK/ Signal) 

Bit 5 BSY(Assert SCSI BSY/ Signal) 

Bit 4 SEL(Assert SCSI SEL/ Signal) 

Bits ATN(Assert SCSI ATN/Signal) 

Bit 2 MSG(Assert SCSI MSG/Signal) 

Bit 1 C/D (Assert SCSI C_D/ Signal) 

Bit 0 I/0(Assert SCSI I_0/ Signal) 

This register is used primarily for diagnostic testing 
or programmed FO operation. It is controlled by 
the SCRIPTS processor when executing SCSI 
SCRIPTS. SOCL should only be used when trans¬ 
ferring data via programmed FO. Some bits are set 
(1) or reset (0) when executing SCSI SCRIPTS. 
Do not write to the register once the SYM53C875 
starts executing normal SCSI SCRIPTS. 
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Register OA (09) 

SCSI Selector ID (SSID) 
Read Only 


VAL 

RES 

RES 

RES 

ENID3 

ENID2 

ENID1 

ENIDO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 X 

X 

X 

0 

0 

0 

0 


Register OB (8B) 

SCSI Bus Control Lines (SBCL) 
Read Only 


REQ 

■iWM 

BSY 

SEL 



C/D 

I/O 

7 

m 

5 

4 

■i 

lgl 

1 

0 

Default»> 

X X 

X 

X 

X 

X 

X 

X 


Bit 7 VAL (SCSI VaHd) 

IfVAL is asserted, the two SCSI IDs were 
detected on the bus during a bus-initiated 
selection or reselection, and the encoded desti¬ 
nation SCSI ID bits below are valid. IfVAL is 
deasserted, only one ID was present and the 
contents of the encoded destination ID are 
meaningless. 

Bits 6-4 Reserved 

Bits 3-0 Encoded Destination SCSI ID 

Reading the SSID register immediately after 
the SYM53C875 has been selected or rese¬ 
lected returns the binary-encoded SCSI ID of 
the device that performed the operation. These 
bits are invalid for targets that are selected 
under the single initiator option of the SCSI-1 
specification. This condition can be detected 
by examining the VAL bit above. 


Bit 7 REQ (SREQ/ Status) 

Bit 6 ACK (SACK/ Status) 

Bit 5 BSY (SBSYI Status) 

Bit 4 SEL (SSEL/ Status) 

Bit 3 ATN (SATN/ Status) 

Bit 2 MSG (SMSG/ Status) 

Bit 1 C/D (SC_D/ Status) 

Bit 0 I/O (SI_0/ Status) 

When read, this register returns the SCSI control 
line status. A bit will be set when the corresponding 
SCSI control line is asserted. These bits are not 
latched; they are a true representation of what is on 
the SCSI bus at the time the register is read. The re¬ 
sulting read data is synchronized before being pre¬ 
sented to the PCI bus to prevent parity errors from 
being passed to the system. This register can be 
used for diagnostics testing or operation in low level 
mode. 


SYM53C875 Data Manual 


5-17 


















Operating Registers 


Register OC (8C) 

DMA Status (DSTAT) 
Read Only 


DFE 

MDPE 

BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 0 

0 

0 

0 

0 

X 

0 


Reading this register will clear any bits that are set 
at the time the register is read, but will not neces¬ 
sarily clear the register because additional inter¬ 
rupts may be pending (the SYM53C875 stacks 
interrupts). The DIP bit in the ISTAT register will 
also be cleared. DMA interrupt conditions may be 
individually masked through the DIEN register. 

When performing consecutive 8-bit reads of the 
DSTAT, SISTO and SISTl registers (in any or¬ 
der), insert a delay equivalent to 12 CLK periods 
between the reads to ensure that the interrupts clear 
properly. See Chapter 2, “Functional Description,” 
for more information on interrupts. 

Bit 7 DFE (DMA FIFO Empty) 

This status bit is set when the DMA FIFO is 
empty. It may be used to determine if any data 
resides in the FIFO when an error occurs and 
an interrupt is generated. This bit is a pure sta¬ 
tus bit and will not cause an interrupt. 

Bit 6 MDPE (Master Data Parity Error) 

This bit is set when the SYM53C875 as a mas¬ 
ter detects a data parity error, or a target device 
signals a parity error during a data phase. This 
bit is completely disabled by the Master Parity 
Error Enable bit (bit 3 of CTEST4). 

Bit 5 BF (Bus Fault) 

This bit is set when a PCI bus fault condition 
is detected. A PCI bus fault can only occur 
when the SYM53C875 is bus master, and is 
defined as a cycle that ends with a Bad Address 
or Target Abort Condition. 


Bit 4 ABRT (Aborted) 

This bit is set when an abort condition occurs. 
An abort condition occurs when a software 
abort command is issued by setting bit 7 of the 
ISTAT register. 

Bit 3 SSI (Single Step Interrupt) 

If the Single-Step Mode bit in the DCNTL 
register is set, this bit will be set and an inter¬ 
rupt generated after successful execution of 
each SCRIPTS instruction. 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received) 

This status bit is set whenever an Interrupt 
instruction is evaluated as true. 

Bit 1 EBPI (Extended Byte Parity Error 

Interrupt) (53C875N only) 

This bit is set whenever the SYM53C875 
detects a parity error on one of the four addi¬ 
tional parity pins on the SYM53C875N. 

Bit 0 IID (Illegal Instruction Detected) 

This status bit will be set any time an illegal or 
reserved instruction op code is detected, 
whether the SYM53C875 is operating in sin¬ 
gle-step mode or automatically executing SCSI 
SCRIPTS. Any of the following conditions 
during instruction execution will also cause 
this bit to be set: 

1. The SYM53C875 is executing a Wait 
Disconnect instruction and the SCSI REQ 
line is asserted without a disconnect 
occurring. 

2. A Block Move instruction is executed with 
OOOOOOh loaded into the DBC register, 
indicating that zero b 5 rtes are to be moved. 

3. During a Transfer Control instruction, the 
Compare Data (bit 18) and Compare 
Phase (bit 17) bits are set in the DBC 
register while the SYM53C875 is in target 
mode. 
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4. During a Transfer Control instruction, the 
Carry Test bit (bit 21) is set and either the 
Compare Data (bit 18) or Compare Phase 
(bit 17) bit is set. 

5. A Transfer Control instruction is executed 
with the reserved bit 22 set. 

6. A Transfer Control instruction is executed 
with the Wait for Valid phase bit (bit 16) set 
while the chip is in target mode. 

7. A Load/Store instruction is issued with the 
memory address mapped to the operating 
registers of the chip, not including ROM or 
RAM. 

8. A Load/Store instruction is issued when 
the register address is not aligned with the 
memory address 

9. A Load/Store instruction is issued with bit 
5 in the DCMD register clear or bits 3 or 2 
set. 

10. A Load/Store instruction when the count 
value in the DEC register is not set at 1 to 
4. 

11. A Load/Store instruction attempts to cross 
a dword boundary. 

12. A Memory Move instruction is executed 
with one of the reserved bits in the DCMD 
register set. 

13. A Memory Move instruction is executed 
with the source and destination addresses 
not byte-aligned. 


Register OD (8D) 

SCSI Status Zero (SSTATO) 
Read Only 


ILF 

ORF 

OLF 

AlP 

LOA 

WOA 

RST 

SDPO/ 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ILF (SIDL Least Significant Byte 
FuU) 

This bit is set when the least significant byte in 
the SCSI Input Data Latch register (SIDL) 
contains data. Data is transferred from the 
SCSI bus to the SCSI Input Data Latch regis¬ 
ter before being sent to the DMA FIFO and 
then to the host bus. The SIDL register con¬ 
tains SCSI data received asynchronously. Syn¬ 
chronous data received does not flow through 
this register. 

Bit 6 ORF (SODR Least Significant Byte 
Full) 

This bit is set when the least significant bj^e in 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
contains data. The SODR register is used by 
the SCSI logic as a second storage register 
when sending data synchronously. It cannot be 
read or written by the user. This bit can be 
used to determine how many bytes reside in 
the chip when an error occurs. 

Bit 5 OLF (SODL Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Output Data Latch (SODL) contains 
data. The SODL register is the interface 
between the DMA logic and the SCSI bus. In 
synchronous mode, data is transferred from 
the host bus to the SODL register, and then to 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
before being sent to the SCSI bus. In as 5 m- 
chronous mode, data is transferred from the 
host bus to the SODL register, and then to the 
SCSI bus. The SODR buffer register is not 
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used for as 5 nichronous transfers. This bit can 
be used to determine how many bytes reside in 
the chip when an error occurs. 

Bit 4 AIP (Arbitration in Progress) 

Arbitration in Progress (AIP =1) indicates that 
the SYM53C875 has detected a Bus Free con¬ 
dition, asserted BSY, and asserted its SCSI ID 
onto the SCSI bus. 

Bit 3 LOA (Lost Arbitration) 

When set, LOA indicates that the 
SYM53C875 has detected a bus free condi¬ 
tion, arbitrated for the SCSI bus, and lost arbi¬ 
tration due to another SCSI device asserting 
the SEL/ signal. 

Bit 2 WOA (Won Arbitration) 

When set, WOA indicates that the 
SYM53C875 has detected a Bus Free condi¬ 
tion, arbitrated for the SCSI bus and won arbi¬ 
tration. The arbitration mode selected in the 
SCNTLO register must be full arbitration and 
selection for this bit to be set. 

Bit 1 RST/ (SCSI RST/ Signal) 

This bit reports the current status of the SCSI 
RST/ signal, and the RST signal (bit 6) in the 
ISTAT register. This bit is not latched and may 
be changing when read. 

Bit 0 SDPO/ (SCSI SDPO/ Parity Signal) 

This bit represents the active high current sta¬ 
tus of the SCSI SDPO/ parity signal. This signal 
is not latched and may be changing as it is 
read. 


Register OE (8E) 

SCSI Status One (SSTATl) 
Read Only 


FF3 

7 

FF2 

6 

FF1 

5 

FFO 

4 

SDPOL 

3 

MSG 

2 

C/D 

1 

I/O 

0 

Default»> 

0 0 

0 

0 

X 

X 

X 

X 

Bits 7-4 FF3-FF0 (FIFO Flags) 

These four bits, along with SSTAT2 bit 4, 
define the number of bytes or words that cur¬ 
rently reside in the SYM53C875’s SCSI syn¬ 
chronous data FIFO. These bits are not latched 
and they will change as data moves through the 
FIFO. 

FF4 

(SSTAT2 
bit 4) 

FF3 

FF2 

FF1 

FFO 

Bytes or 
Words in 
the SCSI 
FIFO 

0 


0 

0 

0 

0 


0 

0 


0 

0 

0 

1 


1 

0 


0 

0 

1 

0 


2 

0 


0 

0 

1 

1 


3 

0 


0 

1 

0 

0 


4 

0 


0 

1 

0 

1 


5 

0 


0 

1 

1 

0 


6 

0 


0 

1 

1 

1 


7 

0 


1 

0 

0 

0 


8 

0 


1 

0 

0 

1 


9 

0 


1 

0 

1 

0 


10 

0 


1 

0 

1 

1 


11 

0 


1 

1 

0 

0 


12 

0 


1 

1 

0 

1 


13 

0 


1 

1 

1 

0 


14 

0 


1 

1 

1 

1 


15 

1 


0 

0 

0 

0 


16 
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Bit 3 SDPOL (Latched SCSI Parity) 

This bit reflects the SCSI parity signal 
(SDPO/), corresponding to the data latched in 
the SCSI Input Data Latch register (SIDL). It 
changes when a new byte is latched into the 
least significant byte of the SIDL register. This 
bit is active high, in other words, it is set when 
the parity signal is active. 

Bit 2 MSG (SCSI MSG/ Signal) 

Bit 1 C/D (SCSI C_D/ Signal) 

Bit 0 I/O (SCSI I_0/ Signal) 

These SCSI phase status bits are latched on the as¬ 
serting edge of SREQ/ when operating in either ini¬ 
tiator or target mode. These bits are set when the 
corresponding signal is active. They are useful 
when operating in low level mode. 


Register OF (8F) 

SCSI Status Two (SSTAT2) 
(Read Only) 


ILF1 

0RF1 

0LF1 

FF4 

SPL1 

RES 

LDSC 

SDP1 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

X 

X 

1 

X 


Bit 7 ILFl (SIDL Most Significant Byte Full) 

This bit is set when the most significant byte in 
the SCSI Input Data Latch register (SIDL) 
contains data. Data is transferred firom the 
SCSI bus to the SCSI Input Data Latch regis¬ 
ter before being sent to the DAIA FIFO and 
then to the host bus. The SIDL register con¬ 
tains SCSI data received asynchronously. Syn¬ 
chronous data received does not flow through 
this register. 

Bit 6 ORFl (SODR Most Significant Byte 
Full) 

This bit is set when the most significant b 5 ^e in 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
contains data. The SODR register is used by 
the SCSI logic as a second storage register 
when sending data synchronously. It is not 
accessible to the user. This bit can be used to 
determine how many bytes reside in the chip 
when an error occurs. 

Bit 5 OLFl (SODL Most Significant Byte 
Fufi) 

This bit is set when the most significant byte in 
the SCSI Output Data Latch (SODL) contains 
data. The SODL register is the interface 
between the DMA logic and the SCSI bus. In 
synchronous mode, data is transferred from 
the host bus to the SODL register, and then to 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
before being sent to the SCSI bus. In asyn¬ 
chronous mode, data is transferred firom the 
host bus to the SODL register, and then to the 
SCSI bus. The SODR buffer register is not 
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used for asjTichronous transfers. This bit can 
be used to determine how many b 5 ^es reside in 
the chip when an error occurs. 

Bit 4 FF4 (FIFO Flags bit 4) 

This is the most significant bit in the SCSI 
FIFO Flags field, with the rest of the bits in 
SSTATl. For a complete description of this 
field, see the definition for SSTATl bits 7-4. 

Bit 3 SPLl (Latched SCSI parity for 

SD15-8) 

This active high bit reflects the SCSI odd par¬ 
ity signal corresponding to the data latched 
into the most significant byte in the SIDL reg¬ 
ister. 

Bit 2 DIFFSENSE SENSE 

If this bit is reset, the correct cable type has 
been connected for the differential operation. 
If this bit is set, a single-ended cable has been 
connected to the device’s DIFFSENSE pin. 

Bit 1 LDSC (Last Disconnect) 

Used in conjunction with the Connected 
(CON) bit in SCNTLl, this status bit allows 
the user to detect the case in which a target 
device disconnects, and then some SCSI 
device selects or reselects, the SYM53C875. If 
the Connected bit is asserted and the LDSC 
bit is asserted, a disconnect has occurred. This 
bit is set when the Connected bit in SCNTLl 
is off. This bit is cleared when a Block Move 
instruction is executed while the Connected bit 
in SCNTLl is on. 

Bit 0 SDPl (SCSI SDPl Signal) 

This bit represents the active-high current state 
of the SCSI SDPl parity signal. It is unlatched 
and may be changing as it is read. 


Registers 10-13 (90-93) 

Data Structure Address (DSA) 

Read/Write 

This 32-bit register contains the base address used 
for all table indirect calculations. The DSA register 
is usually loaded prior to starting an I/O, but it is 
possible for a SCRIPTS Memory Move to load the 
DSA during the I/O. 

During any Memory-to-Memory Move operation, 
the contents of this register are preserved. The 
power-up value of this register is indeterminate. 
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Register 14 (94) 
Interrupt Status (ISTAT) 
(Read/Write) 


ABRT 

SRST 

SIGP 

SEM 

CON 

INTF 

SIP 

DIP 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


This is the only register that can be accessed by the 
host CPU while the SYM53C875 is executing 
SCRIPTS (without interfering in the operation of 
the SYM53C875). It may be used to poll for inter¬ 
rupts if hardware interrupts are disabled. There 
may be stacked interrupts pending; read this regis¬ 
ter after servicing an interrupt to check for stacked 
interrupts. For more information on interrupt han¬ 
dling refer to Chapter 2, ‘functional Description.^" 

Bit 7 ABRT (Abort Operation) 

Setting this bit aborts the current operation 
being executed by the SYM53C875. If this bit 
is set and an interrupt is received^ reset this bit 
before reading the DSTAT register to prevent 
further aborted interrupts from being gener¬ 
ated. The sequence to abort any operation is: 

1. Set this bit. 

2. Wait for an interrupt. 

3. Read the ISTAT register. 

4. If the SCSI Interrupt Pending bit is set, 
then read the SISTO or SISTl register to 
determine the cause of the SCSI Interrupt 
and go back to Step 2. 

5. If the SCSI Interrupt Pending bit is clear, 
and the DMA Interrupt Pending bit is set, 
then write OOh value to this register. 

6. Read the DSTAT register to verify the 
aborted interrupt and to see if any other 
interrupting conditions have occurred. 


Bit 6 SRST (Software Reset) 

Setting this bit resets the SYM53C875o All 
operating registers are cleared to their respec¬ 
tive default values and all SCSI signals are 
deasserted. Setting this bit does not cause the 
SCSI RST/ signal to be asserted. This reset will 
not clear the 53C700 Compatibility bit or any 
of the PCI configuration registers. This bit is 
not self-clearing; it must be cleared to clear the 
reset condition (a hardware reset will also clear 
this bit). 

Bit 5 SIGP (Signal Process) 

SIGP is a R/W bit that can be written at any 
time, and polled and reset via CTEST2.The 
SIGP bit can be used in various ways to pass a 
flag to or from a running SCRIPTS instruc¬ 
tion. 

The only SCRIPTS instruction directly 
affected by the SIGP bit is Wait For Selection/ 
Reselection. Setting this bit causes that 
instruction to jump to the alternate address 
immediately. The instructions at the alternate 
jump address should check the status of SIGP 
to determine the cause of the jump. The SIGP 
bit may be used at any time and is not 
restricted to the wait for selection/ reselection 
condition. 

Bit 4 SEM (Semaphore) 

This bit can be set by the SCRIPTS processor 
using a SCRIPTS register write instruction. 
The bit may also be set by an external proces¬ 
sor while the SYM53C875 is executing a 
SCRIPTS operation. This bit enables the 
SYM53C875 to notify an external processor of 
a predefined condition while SCRIPTS are 
running. The external processor may also 
notify the SYM53C875 of a predefined condi¬ 
tion and the SCRIPTS processor may take 
action while SCRIPTS are executing. 
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Bit 3 CON (Connected) 

This bit is automatically set any time the 
SYM53C875 is connected to the SCSI bus as 
an initiator or as a target. It will be set after 
successfully completing selection or when the 
SYM53C875 has responded to a bus-initiated 
selection or reselection. It will also be set after 
the SYM53C875 wins arbitration when oper¬ 
ating in low level mode. When this bit is clear, 
the SYM53C875 is not connected to the SCSI 
bus. 

Bit 2 INTF (Interrupt on the Fly) 

This bit is asserted by an INTFLY instruction 
during SCRIPTS execution. SCRIPTS pro¬ 
grams will not halt when the interrupt occurs. 
This bit can be used to notify a service routine, 
running on the main processor while the 
SCRIPTS processor is still executing a 
SCRIPTS program. If this bit is set, when the 
ISTAT register is read it will not automatically 
be cleared. To clear this bit, it must be written 
to a one. The reset operation is self-clearing. 

Note: if the INTF bit is set but SIP or DIP is not 
set, do not attempt to read the other chip 
status registers. An interrupt-on-the-fly 
interrupt must be cleared before servicing 
any other interrupts indicated by SIP or 
DIP. 

Note: this bit must be written to one in order to 
clear it after it has been set. 


Bit 1 SIP (SCSI Interrupt Pending) 

This status bit is set when an interrupt condi¬ 
tion is detected in the SCSI portion of the 
SYM53C875.The following conditions will 
cause a SCSI interrupt to occur: 

■ A phase mismatch (initiator mode) or 
SATN/ becomes active (target mode) 

■ An arbitration sequence completes 

■ A selection or reselection time-out occurs 

■ The SYM53C875 was selected 

■ The SYM53C875 was reselected 

■ A SCSI gross error occurs 

■ An unexpected disconnect occurs 

■ A SCSI reset occurs 

■ A parity error is detected 

■ The handshake-to-handshake timer is 
expired 

■ The general purpose timer is expired. 

To determine exactly which condition(s) 
caused the interrupt, read the SISTO and 
SISTl registers. 

Bit 0 DIP (DMA Interrupt Pending) 

This status bit is set when an interrupt condi¬ 
tion is detected in the DMA portion of the 
SYM53C875.The following conditions will 
cause a DMA interrupt to occur: 

■ A PCI parity error is detected 

■ A bus fault is detected 


■ An abort condition is detected 

■ A SCRIPTS instruction is executed in 
single-step mode 

■ A SCRIPTS interrupt instruction is 
executed 

■ An illegal instruction is detected. 

To determine exactly which condition(s) 
caused the interrupt, read the DSTAT register. 
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Register 18 (98) 

Chip Test Zero (CTESTO) 

Read/Write 

This was a general purpose read/write register in 
previous SYM53C8XX family chips. Although it is 
still a read/write register, S 5 rmbios reserves the right 
to use these bits for future 53C8XX family en¬ 
hancements. 


Register 19 (99) 

Chip Test One (CTESTl) 
Read Only 


FMT3 

FMT2 

FMT1 

FMTO 

FFL3 

FFL2 

FFL1 

FFLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

1 

1 

0 

0 

0 

0 


Bits 7-4 FMT3-0 (Byte Empty in DMA 
FIFO) 

These bits identify the bottom bytes in the 
DMA FIFO that are empty. Each bit corre¬ 
sponds to a byte lane in the DMA FIFO. For 
example, if byte lane three is empty, then 
FMT3 will be set. Since the FMT flags indi¬ 
cate the status of bytes at the bottom of the 
FIFO, if all FMT bits are set, the DMA FIFO 
is empty. 


Bits 3-0 FFL3-0 (Byte Full in DMA FIFO) 

These status bits identify the top bytes in the 
DMA FIFO that are full. Each bit corresponds 
to a byte lane in the DMA FIFO. For example, 
if byte lane three is full then FFL3 will be set. 
Since the FFL flags indicate the status of bytes 
at the top of the FIFO, if all FFL bits are set, 
the DMA FIFO is full. 


SYM53C875 Data Manual 


5-25 




Operating Registers 


Register lA (9A) 

Chip Test Two (CTEST2) 
Read/Wiite 


DDIR 

SIGP 

CIO 

CM 

SRTCH 

TEOP 

DREQ 

DACK 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

X 

X 

0 

0 

0 

1 


Bit 7 DDIR (Data Transfer Direction) 

This status bit indicates which direction data is 
being transferred. When this bit is set, the data 
will be transferred from the SCSI bus to the 
host bus. When this bit is clear, the data will be 
transferred from the host bus to the SCSI bus. 

Bit 6 SIGP (Signal Process) 

This bit is a copy of the SIGP bit in the ISTAT 
register (bit 5).The SIGP bit is used to signal a 
running SCRIPTS instruction. When this reg¬ 
ister is read, the SIGP bit in the ISTAT register 
is cleared. 

Bit 5 CIO (Configured as I/O) 

This bit is defined as the Configuration I/O 
Enable Status bit. This read-only bit indicates 
if the chip is currently enabled as I/O space. 

Note: both bits 4 and 5 may be set if the chip is 
dual-mapped. 

Bit 4 CM (Configured as Memory) 

This bit is defined as the configuration mem¬ 
ory enable status bit. This read-only bit indi¬ 
cates if the chip is currently enabled as 
memory space. 

Note: both bits 4 and 5 may be set if the chip is 
dual-mapped. 

Bit 3 SRTCH (SCRATCHA/B Operation) 

This bit controls the operation of the 
SCRATCHA and SCRATCHB registers. 
When it is set, SCRATCHB contains the RAM 
base address value from the PCI configuration 
RAM Base Address register. This is the base 
address for the 4 KB internal RAM. In addi¬ 
tion, the SCRATCHA register displays the 
memory-mapped based address of the chip 


operating registers. When this bit is clear, the 
SCRATCHA and SCRATCHB registers 
return to normal operation. 

Note: bit 3 is the only writable bit in this register. 
All other bits are read only. When 
modifying this register, all other bits must 
be written to zero. Do not execute a Read- 
Modify-Write to this register. 

Bit 2 TEOP (SCSI True End of Process) 

This bit indicates the status of the 
SYM53C875’s internal TEOP signal. The 
TEOP signal acknowledges the completion of 
a transfer through the SCSI portion of the 
SYM53C875.When this bit is set,TEOP is 
active. When this bit is clear, TEOP is inactive. 

Bit 1 DREQ (Data Request Status) 

This bit indicates the status of the 
SYM53C875’s internal Data Request signal 
(DREQ).When this bit is set, DREQ is active. 
When this bit is clear, DREQ is inactive. 

Bit 0 DACK (Data Acknowlec^e Status) 

This bit indicates the status of the 
SYM53C875’s internal Data Acknowledge sig¬ 
nal (DACK/).When this bit is set, DACK/ is 
inactive. When this bit is clear, DACK/ is 
active. 
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Register IB (9B) 

Chip Test Three (CTEST3) 
Read/Write 


V3 

V2 

V1 

VO 

FLF 

CLF 

FM 

WRIE 

7 

6 

5 

4 

3 

2 

1 

0 


Default»> 


Bit 0 WRIE (Write and Invalidate Enable) 

This bit, when set, causes Memory Write and 
Invalidate commands to be issued on the PCI 
bus after certain conditions have been met. 
These conditions are described in detail in 
Chapter 3. 


Bits 7-4 V3-V0 (Chip revision level) 

These bits identify the chip revision level for 
software purposes. The value should be the 
same as the lower nibble of the PCI Revision 
ID Register, at address 08h in configuration 
space. 

Bit 3 FLF (Flush DMA FIFO) 

When this bit is set, data residing in the DMA 
FIFO is transferred to memory, starting at the 
address in the DNAD register. The internal 
DMAWR signal, controlled by the CTEST5 
register, determines the direction of the trans¬ 
fer. This bit is not self clearing; once the 
SYM53C875 has successfully transferred the 
data, this bit should be reset. 

Note: polling of FIFO flags is allowed during 
flush operations. 

Bit 2 CLF (Clear DMA FIFO) 

When this bit is set, all data pointers for the 
DAIA FIFO are cleared. Any data in the FIFO 
is lost. This bit automatically resets after the 
SYM53C875 has successfully cleared the 
appropriate FIFO pointers and registers. 

Note: this bit does not clear the data visible at the 
bottom of the FIFO. 

Bit 1 FM (Fetch Pin Mode) 

When set, this bit causes the FETCH/ pin to 
deassert during indirect and table indirect read 
operations. FETCH/ will only be active during 
the op code portion of an instruction fetch. 
This allows SCRIPTS to be stored in a PROM 
while data tables are stored in RAM. 

If this bit is not set, FETCH/ will be asserted 
for all bus cycles during instruction fetches. 
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Registers 1C-IF (9C-9F) 

Temporary (TEMP) 

Read/Write 

This 32-bit register stores the Return instruction 
address pointer from the Call instruction. The ad¬ 
dress pointer stored in this register is loaded into 
the DSP register when a Return instruction is exe¬ 
cuted. This address points to the next instruction to 
be executed. Do not write to this register while the 
SYM53C875 is executing SCRIPTS. 

During any Memory-to-Memory Move operation, 
the contents of this register are preserved. The 
power-up value of this register is indeterminate. 


Register 20 (AO) 
DMA FIFO (DFIFO) 
Read/Write 


B07 

B06 

BOS 

B04 

Bo3 

B02 

B01 

BOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 BO7-BO0 (Byte offset counter) 

These bits, along with bits 1-0 in the CTEST5 
register, indicate the amount of data trans¬ 
ferred between the SCSI core and the DMA 
core. It may be used to determine the number 
of bjTtes in the DMA FIFO when an interrupt 
occurs. These bits are unstable while data is 
being transferred between the two cores; once 
the chip has stopped transferring data, these 
bits are stable. 

Since the DFIFO register counts the number 
of bjTtes transferred between the DMA core 
and the SCSI core, and the DBC register 
counts the number of b 3 l:es transferred across 
the host bus, the difference between these two 
counters represents the number of bytes 
remaining in the DMA FIFO. 

The following steps will determine how many 
bytes are left in the DMA FIFO when an error 
occurs, regardless of the direction of the trans¬ 
fer: 

1. If the DMA FIFO size is set to 88 bytes, 
sSubtract the seven least significant bits of 
the DBC register from the 7-bit value of 
the DFIFO register. 

If the DAIA FIFO size is set to 536 b 5 rtes 
(using bit 5 of the CTEST5 register), sub¬ 
tract the 10 least significant bits of the 
DBC register from the 10-bit value of the 
DMA FIFO Byte Offset Counter, which 
consists of bits 1-0 in the CTEST5 register 
and bits 7-0 of the DMA FIFO register. 

2. If the DMA FIFO size is set to 88 bytes, 
AND the result with 7Fh for a byte count 
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between zero and 64. If the DMA FIFO 
size is set to 536 bytes, AND the result with 
3FFh for a byte count between 0 and 536. 

Note: to calculate the total number of b 5 rtes in 
both the DMA FIFO and SCSI logic, see 
the section on Data Paths in Chapter Two, 
“Functional Description.” 


Register 21 (Al) 

Chip Test Four (CTEST4) 
Read/Write 


BDIS 

ZMOD 

ZSD 

SRTM 

MPEE 

FBL2 

FBL1 

FBLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 BDIS (Burst Disable) 

When set, this bit will cause the SYM53C875 
to perform back to back cycles for all transfers. 
When reset, the SYM53C875 will perform 
back to back transfers for op code fetches and 
burst transfers for data moves. 

Bit 6 ZMOD (High Impedance Mode) 

Setting this bit causes the SYM53C875 to 
place all output and bidirectional pins into a 
high-impedance state. In order to read data out 
of the SYM53C875, this bit must be cleared. 
This bit is intended for board-level testing only. 
Do not set this bit during normal system oper¬ 
ation. 

Bit 5 ZSD (SCSI Data High Impedance) 

Setting this bit causes the SYM53C875 to 
place the SCSI data bus SD(15-0) and the par¬ 
ity lines SDP(l-O) in a high-impedance state. 
In order to transfer data on the SCSI bus, this 
bit must be cleared. 

Bit 4 SRTM (Shadow Register Test Mode) 

Setting this bit allows access to the shadow reg¬ 
isters used by memory-to-memory Move oper¬ 
ations. When this bit is set, register accesses to 
the TEMP and DSA registers are directed to 
the shadow copies STEMP (Shadow TEMP) 
and SDSA (Shadow DSA).The registers are 
shadowed to prevent them from being over¬ 
written during a Memory-to-Memory Move 
operation. The DSA and TEMP registers con¬ 
tain the base address used for table indirect 
calculations, and the address pointer for a call 
or return instruction, respectively. This bit is 
intended for manufacturing diagnostics only 
and should not be set during normal opera¬ 
tions. 
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Bit 3 IVIPEE (Master Parity Error Enable) 

Setting this bit enables parity checking during 
master data phases. A parity error during a bus 
master read is detected by the SYM53C875. A 
parity error during a bus master write is 
detected by the target, and the SYM53C875 is 
informed of the error by the PERR/ pin being 
asserted by the target. When this bit is reset, 
the SYM53C875 will not interrupt if a master 
parity error occurs. This bit is reset at power 
up. 

Bits 2-0 FBL2-FBL0 (FIFO Byte Control) 


FBL2 

FBLl 

FBLO 

DMA FIFO 
Byte lane 

Pins 

0 

X 

X 

Disabled 

n/a 

1 

0 

0 

0 

D(7-0) 

1 

0 

1 

1 

D(15-8) 

1 

1 

0 

2 

D(23-16) 

1 

1 

1 

3 

D(31-24) 


These bits steer the contents of the CTEST6 
register to the appropriate byte lane of the 32- 
bit DMA FIFO. If the FBL2 bit is set, then 
FBLl and FBLO determine which of four byte 
lanes can be read or written. When cleared, the 
bjte lane read or written is determined by the 
current contents of the DNAD and DBG regis¬ 
ters. Each of the four bytes that make up the 
32-bit DMA FIFO can be accessed by writing 
these bits to the proper value. For normal 
operation, FBL2 must equal zero. 


Register 22 (A2) 

Chip Test Five (CTEST5) 
Read/Write 


ADCK 

BBCK 

DFS 

MASR 

DDIR 

BL2 

B09 

BOB 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

X 

X 

X 


Bit 7 ADCK (Clock Address Incrementor) 

Setting this bit increments the address pointer 
contained in the DNAD register. The DNAD 
register is incremented based on the DNAD 
contents and the current DBC value. This bit 
automatically clears itself after incrementing 
the DNAD register. 

Bit 6 BBCK (Clock Byte Counter) 

Setting this bit decrements the b 5 rte count con¬ 
tained in the 24-bit DBC register. It is decre¬ 
mented based on the DBC contents and the 
current DNAD value. This bit automatically 
clears itself after decrementing the DBC regis¬ 
ter. 

Bit 5 DFS (DMA FIFO Size) 

This bit controls the size of the DMA FIFO. 
When clear, the DMA FIFO will appear to be 
only 88 bytes deep. When set, the DMA FIFO 
size will increase to 536 bytes. Using an 88- 
byte FIFO allows software written for other 
SYM53C8XX family chips to properly calcu¬ 
late the number of bytes residing in the chip 
after a target disconnect. The default value of 
this bit is zero. 

Bit 4 MASK (Master Control for Set or 
Reset Pulses) 

This bit controls the operation of bit 3. When 
this bit is set, bit 3 asserts the corresponding 
signals. When this bit is reset, bit 3 deasserts 
the corresponding signals. This bit and bit 3 
should not be changed in the same write cycle. 
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Bit 3 DDIR (DMA Direction) 

Setting this bit either asserts or deasserts the 
internal DMA Write (DMAWR) direction sig¬ 
nal depending on the current status of the 
MASK bit in this register* Asserting the 
DMAWR signal indicates that data will be 
transferred from the SCSI bus to the host bus. 
Deasserting the DMAWR signal transfers data 
from the host bus to the SCSI bus. 

Bit 2 BL2 (Burst Length bit 2) 

This bit works with bits 6 and 7 in the 
DMODE register to determine the burst 
length. For complete definitions of this field, 
refer to the descriptions of DMODE bits 6 and 
7. This bit is disabled if an 88-byte FIFO is 
selected by clearing the DMA FIFO Size bit. 

Bits 1-0 B09-8 

These are the upper two bits of the DMA 
FIFO byte offset counter. The entire field is 
described under the DFIFO register, bits 7-0. 


Register 23 (A3) 

Chip Test Six (CTEST6) 
Read/Write 


DF7 

DF6 

DF5 

DF4 

DF3 

DF2 

DF1 

DFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 DF7-DF0 (DMA FIFO) 

Writing to this register writes data to the 
appropriate b 5 ^e lane of the DMA FIFO as 
determined by the FBL bits in the CTEST4 
register. Reading this register unloads data 
from the appropriate byte lane of the DMA 
FIFO as determined by the FBL bits in the 
CTEST4 register. Data written to the FIFO is 
loaded into the top of the FIFO. Data read out 
of the FIFO is taken from the bottom. To pre¬ 
vent DMA data from being corrupted, this reg¬ 
ister should not be accessed before starting or 
restarting SCRIPTS operation. This register 
should only be written when testing the DMA 
FIFO using the CTEST4 register. Writes to 
this register while the test mode is not enabled 
will have unexpected results. 
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Registers 24-26 (A4-A6) 

DAIA Byte Counter (DBG) 

Read/Write 

This 24-bit register determines the number of b 5 rtes 
to be transferred in a Block Move instruction. 
While sending data to the SCSI bus, the counter is 
decremented as data is moved into the DMA FIFO 
from memory. While receiving data from the SCSI 
bus, the counter is decremented as data is written 
to memory from the SYM53C875. The DBC 
counter is decremented each time that data is trans¬ 
ferred on the PCI bus. It is decremented by an 
amount equal to the number of bytes that were 
transferred. 

The maximum number of bytes that can be trans¬ 
ferred in any one Block Move command is 
16,777,215 bytes. The maximum value that can be 
loaded into the DBC register is FFFFFFh. If the 
instruction is a Block Move and a value of OOOOOOh 
is loaded into the DBC register, an illegal instruc¬ 
tion interrupt will occur if the SYM53C875 is not 
in target mode. Command phase. 

The DBC register is also used to hold the least sig¬ 
nificant 24 bits of the first dword of a SCRIPT 
fetch, and to hold the offset value during table indi¬ 
rect I/O SCRIPTS. For a complete description, see 
Chapter Six, “Instruction Set of the I/O Proces¬ 
sor.” The power-up value of this register is indeter¬ 
minate. 


Register 27 (A7) 

DMA Command (DCMD) 

Read/Write 

This 8-bit register determines the instruction for 
the SYM53C875 to execute. This register has a dif¬ 
ferent format for each instruction. For complete de¬ 
scriptions, see Chapter Six, “Instruction Set of the 
I/O Processor.” 


5-32 


SYM53C875 Data Manual 




Operating Registers 


Registers 28-2B (A8-AB) 

DMA Next Address (DNAD) 

Read/Write 

This 32-bit register contains the general purpose 
address pointer. At the start of some SCRIPTS op- 
erations^ its value is copied from the DSPS register. 
Its value may not be valid except in certain abort 
conditions. The default value of this register is zero. 

This register should not be used to determine data 
addresses during a Phase Mismatch interrupt, as its 
value is not always correct for this use. The DBG, 
DFIFO, and DSPS registers should be used to cal¬ 
culate residual byte counts and addresses as de¬ 
scribed in the Data Paths section of Chapter 2. 


Registers 2C-2F (AC-AF) 

DMA SCRIPTS Pointer (DSP) 

Read/Write 

To execute SCSI SCRIPTS, the address of the first 
SCRIPTS instruction must be written to this regis¬ 
ter. In normal SCRIPTS operation, once the start¬ 
ing address of the SCRIPT is written to this 
register, SCRIPTS are automatically fetched and 
executed until an interrupt condition occurs. 

In single-step mode, there is a single step interrupt 
after each instruction is executed. The DSP register 
does not need to be written with the next address, 
but the Start DMA bit (bit 2, DCNTL register) 
must be set each time the step interrupt occurs to 
fetch and execute the next SCRIPTS command. 
When writing this register eight bits at a time, writ¬ 
ing the upper eight bits begins execution of 
SCSI SCRIPTS. The default value of this register 
is zero. 
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Registers 30-33 (B0-B3) 

DMA SCRIPTS Pointer Save (DSPS) 
Read/Write 

This register contains the second dword of a 
SCRIPTS instruction. It is overwritten each time a 
SCRIPTS instruction is fetched. When a 
SCRIPTS interrupt instruction is executed, this 
register holds the interrupt vector. The power-up 
value of this register is indeterminate. 


Registers 34-37 (B4-B7) 

Scratch Register A (SCRATCH A) 
Read/Write 

This is a general purpose, user-definable scratch 
pad register. Apart firom CPU access, only Register 
Read/Write and Memory Moves into the 
SCRATCH register will alter its contents. The 
SYM53C875 cannot fetch SCRIPTS instructions 
firom this location.When bit 3 in the CTEST2 reg¬ 
ister is set, this register contains the memory- 
mapped base address of the operating registers. 
Setting CTEST2 bit 3 only causes the base address 
to appear in this register; any information that was 
previously in the register will remain intact. Any 
writes to this register while CTEST2 bit 3 is set will 
pass through to the actual SCRATCHA register. 
The power-up value of this register is indetermi¬ 
nate. 
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Register 38 (B8) 

DMA Mode (DMODE) 
ReadA5(7rite 


BL1 

BLO 

SIOM 

DIOM 

ER 

ERMP 

BOF 

MAN 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7-6 BLl-BLO (Burst Length) 

These bits control the maximum number of 
transfers performed per bus ownership, regard¬ 
less of whether the transfers are back-to-back, 
burst, or a combination of both. The 
SYM53C875 asserts the Bus Request (REQ/) 
output when the DMA FIFO can accommo¬ 
date a transfer of at least one burst size of data. 
Bus Request (REQ/) is also asserted during 
start-of-transfer and end-of-transfer cleanup 
and alignment, even though less than a full 
burst of transfers may be performed. The 
SYM53C875 inserts a ‘Tairness delay^’ of four 
CLKs between burst-length transfers (as set in 
BLl-0) during normal operation. The fairness 
delay is not inserted during PCI retry cycles. 
This gives the CPU and other bus master 
devices the opportunity to access the PCI bus 
between bursts. 


BL2 

(CTEST5 
bit 2) 

BL1 

BLO 

Burst Length 

0 

0 

0 

2- transfer burst 

0 

0 

1 

4- transfer burst 

0 

1 

0 

8-transfer burst 

0 

1 

1 

16-transfer burst 

1 

0 

0 

32-transfer burst* 

1 

0 

1 

64-transfer burst* 

1 

1 

0 

128-transfer burst* 

1 

1 

1 

Reserved 


^ Only valid if the FIFO size is set to 536 bytes 


Bit 5 SIOM (Source I/O-Memory Enable) 

This bit is defined as an I/O Memory Enable 
bit for the source address of a Memory Move 
or Block Move Command. If this bit is set, 
then the source address is in FO space; and if 
reset, then the source address is in memory 
space. 

This function is useful for register-to-memory 
operations using the Memory Move instruc¬ 
tion when the SYM53C875 is FO mapped. 

Bits 4 and 5 of the CTEST2 register can be 
used to determine the configuration status of 
the SYM53C875. 

Bit 4 DIOM (Destination I/O-Memory 
Enable) 

This bit is defined as an I/O Memory Enable 
bit for the destination address of a Memory 
Move or Block Move Command. If this bit is 
set, then the destination address is in FO 
space; and if reset, then the destination address 
is in memory space. 

This function is useful for memory-to-register 
operations using the Memory Move instruc¬ 
tion when the SYM53C875 is FO mapped. 
Bits 4 and 5 of the CTEST2 register can be 
used to determine the configuration status of 
the SYM53C875. 

Bit 3 ERL (Enable Read Line) 

This bit enables a PCI Read Line command. If 
PCI cache mode is enabled by setting bits in 
the PCI Cache Line Size register, this chip 
issues a Read Line command on all read cycles 
if other conditions are met. For more informa¬ 
tion on these conditions, refer to Chapter 3. 

Bit 2 ERMP (Enable Read Multiple) 

This bit, when set, will cause Read Multiple 
commands to be issued on the PCI bus after 
certain conditions have been met. These condi¬ 
tions are described in Chapter 3. 
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Bit 1 BOF (Burst Op Code Fetch Enable) 

Setting this bit causes the SYM53C875 to 
fetch instructions in burst mode. Specifically, 
the chip will burst in the first two dwords of all 
instructions using a single bus ownership. If 
the instruction is a memory-to-memory move 
type, the third dword will be accessed in a sub¬ 
sequent bus ownership. If the instruction is an 
indirect type, the additional dword will be 
accessed in a subsequent bus ownership. If the 
instruction is a table indirect block move type, 
the chip will access the remaining two dwords 
in a subsequent bus ownership, thereby fetch¬ 
ing the four dwords required in two bursts of 
two dwords each. This bit has no effect if 
SCRIPTS instruction prefetching is enabled. 

Bit 0 MAN (Manual Start Mode) 

Setting this bit prevents the SYM53C875 firom 
automatically fetching and executing SCSI 
SCRIPTS when the DSP register is written. 
When this bit is set, the Start DMA bit in the 
DCNTL register must be set to begin 
SCRIPTS execution. Clearing this bit causes 
the SYM53C875 to automatically begin fetch¬ 
ing and executing SCSI SCRIPTS when the 
DSP register is written. This bit normally is not 
used for SCSI SCRIPTS operations. 


Register 39 (B9) 

DMA Interrupt Enable (DIEN) 
Read/Write 


RES 

MDPE 

BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

0 

0 

0 

X 

0 


This register contains the interrupt mask bits corre¬ 
sponding to the interrupting conditions described 
in the DSTAT register. An interrupt is masked by 
clearing the appropriate mask bit. Masking an in¬ 
terrupt prevents IRQ/ firom being asserted for the 
corresponding interrupt, but the status bit will still 
be set in the DSTAT register. Masking an interrupt 
will not prevent the ISTAT DIP firom being set. All 
DMA interrupts are considered fatal, therefore 
SCRIPTS will stop running when this condition 
occurs, whether or not the interrupt is masked. Set¬ 
ting a mask bit enables the assertion of IRQ/ for the 
corresponding interrupt. (A masked non-fatal in¬ 
terrupt will not prevent un-masked or fatal inter¬ 
rupts firom getting through; interrupt stacking 
begins when either the ISTAT SIP or DIP bit is 
set.) 

The SYM53C875 IRQ/ output is latched; once as¬ 
serted, it will remain asserted until the interrupt is 
cleared by reading the appropriate status register. 
Masking an interrupt after the IRQ/ output is as¬ 
serted will not cause IRQ/ to be deasserted. 

For more information on interrupts, see Chapter 
Two, “Functional Description.” 
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Bit? 

Reserved 

Register 3A (BA) 

Bit 6 

MDPE (Master Data Parity Error) 

Scratch Byte Register (SBR) 

Read/Write 

Bits 

BF (Bus Fault) 

This is a general purpose register. Apart from CPU 

Bit 4 

ABRT (Aborted) 

access, only Register Read/Write and Memory 
Moves into this register will alter its contents. The 

Bits 

SSI (Single -step Interrupt) 

default value of this register is zero. This register 
was called the DMA Watchdog Timer on previous 

Bit 2 

SIR (SCRIPTS Interrupt 

Instruction Received 

SYM53C8XX family products. 

Bitl 

EBPE (Extended Byte Parity 

Enable) (SYM53C875N only) 


BitO 

IID (Illegal Instruction Detected) 
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Register 3B (BB) 

DMA Control (DCNTL) 
Read/Write 


CLSE 

PFF 

PFEN 

SSM 

IRQM 

STD 

IRQD 

COM 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 CLSE (Cache Line Size Enable) 

Setting this bit enables the SYM53C875 to 
sense and react to cache line boundaries set up 
by the DMODE or PCI Cache Line Size regis¬ 
ter, whichever contains the smaller value. 
Clearing this bit disables the cache line size 
logic and the SYM53C875 monitors the cache 
line size via the DMODE register. 

Bit 6 PFF (I»re-fetch Rush) 

Setting this bit will cause the pre-fetch tmit to 
flush its contents. The bit will reset after the 
flush is complete. 

Bit 5 PFEN (Pre-fetch Enable) 

Setting this bit enables the pre-fetch unit if the 
burst size is equal to or greater than four. For 
more information on SCRIPTS instruction 
prefetching, see Chapter 2. 

Bit 4 SSM (Single-step Mode) 

Setting this bit causes the SYM53C875 to stop 
after executing each SCRIPTS instruction, 
and generate a single step interrupt. When this 
bit is clear the SYM53C875 will not stop after 
each instruction; instead it continues fetching 
and executing instructions until an interrupt 
condition occurs. For normal SCSI SCRIPTS 
operation, this bit should be clear. To restart 
the SYM53C875 after it generates a SCRIPTS 
Step interrupt, the ISTAT and DSTAT regis¬ 
ters should be read to recognize and clear the 
interrupt and then the START DMA bit in this 
register should be set. 

Bit 3 IRQM (IRQ Mode) 

When set, this bit will enable a totem pole 
driver for the IRQ pin. When reset, this bit will 
enable an open drain driver for the IRQ pin 


with a internal weak pull-up. This bit is reset at 
power up. The bit should remain clear to retain 
full PCI compliance. 

Bit 2 STD (Start DMA Operation) 

The SYM53C875 fetches a SCSI SCRIPTS 
instruction from the address contained in the 
DSP register when this bit is set. This bit is 
required if the SYM53C875 is in one of the 
following modes: 

1. Manual start mode - Bit 0 in the DMODE 
register is set 

2. Single-step mode - Bit 4 in the DCNTL 
register is set 

When the SYM53C875 is executing SCRIPTS 
in manual start mode, the Start DMA bit 
needs to be set to start instruction fetches, but 
does not need to be set again until an interrupt 
occurs. When the SYM53C875 is in single- 
step mode, the Start DMA bit needs to be set 
to restart execution of SCRIPTS after a single- 
step interrupt. 

Bit 1 IRQD aRQ Disable) 

Setting this bit disables the IRQ pin; clearing 
the bit enables normal operation. As with any 
other register other than ISTAT, this register 
can not be accessed except by a SCRIPTS 
instruction during SCRIPTS execution. For 
more information on the use of this bit in inter¬ 
rupt handling, see Chapter 2. 

Bit 0 COM (53C700 CompatibUity) 

When this bit is clear, the SYM53C875 will 
behave in a manner compatible with the 
SYM53C700; selection/reselection IDs will be 
stored in both the SSID and SFBR registers. 

When this bit is set, the ID will be stored only 
in the SSID register, protecting the SFBR from 
being overwritten if a selection/reselection 
occurs during a DMA register-to-register oper¬ 
ation. This bit is not affected by a software 
reset. 
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Register 3C-3F (BC-BF) Register 40 (CO) 

Adder Sum Output (ADDER) SCSI Interrupt Enable Zero (SIENO) 

Read Only Read/Write 

This register contains the output of the internal 
adder, and is used primarily for test purposes. The 
power-up value for this register is indeterminate. 

This register contains the interrupt mask bits corre¬ 
sponding to the interrupting conditions described 
in the SISTO register. An interrupt is masked by 
clearing the appropriate mask bit. For more infor¬ 
mation on interrupts, see Chapter 2. 

Bit 7 M/A (SCSI Phase Mismatch - 
Initiator Mode; SCSI ATN 
Condition - Target Mode) 

In initiator mode, this bit is set when the SCSI 
phase asserted by the target and sampled dur¬ 
ing SREQ/ does not match the expected phase 
in the SO CL register. This expected phase is 
automatically written by SCSI SCRIPTS. In 
target mode, this bit is set when the initiator 
has asserted SATN/. See the Disable Halt on 
Parity Error or SATN/ Condition bit in the 
SCNTLl register for more information on 
when this status is actually raised. 

Bit 6 CMP (Function Complete) 

Full arbitration and selection sequence has 
completed. 

Bit 5 SEL (Selected) 

The SYM53C875 has been selected by a SCSI 
target device. The Enable Response to Selec¬ 
tion bit in the SCID register must be set for 
this to occur. 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 


Default»> 

0 0 0 0 0 0 0 0 


Bit 4 RSL (Reselected) 

The SYM53C875 has been reselected by a 
SCSI initiator device. The Enable Response to 
Reselection bit in the SCID register must be 
set for this to occur. 
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Bit 3 SGE (SCSI Gross Error) 

The following conditions are considered SCSI 
Gross Errors; 

1. Data underflow - the SCSI FIFO was read 
when no data was present. 

2. Data overflow - the SCSI FIFO was 
written to while full. 

3. Offset underflow - in target mode, a 
SACK/ pulse was received before the 
corresponding SREQ/ was sent. 

4. Offset overflow - in initiator mode, an 
SREQ/ pulse was received which caused 
the maximum offset (Defined by the M03- 
0 bits in the SXFER register) to be 
exceeded. 

5. In initiator mode, a phase change occurred 
with an outstanding SREQ/SACK offset. 

6. Residual data in SCSI FIFO - a transfer 
other than s 5 mchronous data receive was 
started with data left in the SCSI 
s 5 mchronous receive FIFO. 

Bit 2 UDC (Unexpected Disconnect) 

This condition only occurs in initiator mode. It 
happens when the target to which the 
SYM53C875 is connected disconnects from 
the SCSI bus unexpectedly. See the SCSI Dis¬ 
connect Unexpected bit in the SCNTL2 regis¬ 
ter for more information on expected versus 
unexpected disconnects. Any disconnect in low 
level mode causes this condition. 

Bit 1 RST (SCSI Reset Condition) 

The SRST/ signal has been asserted by the 
SYM53C875 or any other SCSI device. This 
condition is edge-triggered, so multiple inter¬ 
rupts cannot occur because of a single SRST/ 
pulse. 

Bit 0 PAR (SCSI Parity Error) 

The SYM53C875 detected a parity error while 
receiving or sending SCSI data. See the Dis¬ 
able Halt on Parity Error or SATN/ Condition 
bits' in the SCNTLl register for more informa¬ 
tion on when this condition will actually be 
raised. 


Register 41 (Cl) 

SCSI Interrupt Enable One (SEENl) 
Read/Write 


RES 

RES 

RES 

RES 

RES 

STO 

GEN 

HTH 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

X 

X 

X 

0 

0 

0 


This register contains the interrupt mask bits corre¬ 
sponding to the interrupting conditions described 
in the SISTl register. An interrupt is masked by 
clearing the appropriate mask bit. For more infor¬ 
mation on interrupts, refer to Chapter 2, “Fvmc- 
tional Description.” 

Bits 7-3 Reserved 

Bit 2 STO (Selection or Reselection Time¬ 
out) 

The SCSI device which the SYM53C875 was 
attempting to select or reselect did not respond 
within the programmed time-out period. See 
the description of the STIMEO register bits 3-0 
for more information on the time-out timer. 

Bit 1 GEN (General Purpose Timer 

Expired) 

The general purpose timer has expired.The 
time measured is the time between enabling 
and disabling of the timer. See the description 
of the STIMEl register, bits 3-0, for more 
information on the general purpose timer. 

Bit 0 HTH ( Handshake-to-Handshake 

Timer Expired) 

The handshake-to-handshake timer has 
expired. The time measured is the SCSI 
Request-to-Request (target) or Acknowledge- 
to-Acknowledge (initiator) period. See the 
description of the STIMEO register, bits 7-4, 
for more information on the handshake-to- 
handshake timer. 
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Register 42 (C2) 

SCSI Interrupt Status Zero (SISTO) 
Read Only 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Reading the SISTO register returns the status of the 
various interrupt conditions, whether they are en¬ 
abled in the SIENO register or not. Each bit set in¬ 
dicates that the corresponding condition has 
occurred. Reading the SISTO will clear the inter¬ 
rupt status. 

Reading this register will clear any bits that are set 
at the time the register is read, but will not neces¬ 
sarily clear the register because additional inter¬ 
rupts may be pending (the SYM53C875 stacks 
interrupts). SCSI interrupt conditions may be indi¬ 
vidually masked through the SIENO register. 

When performing consecutive 8-bit reads of the 
DSTAT, SISTO, and SISTl registers (in any or¬ 
der), insert a delay equivalent to 12 CLK periods 
between the reads to ensure the interrupts clear 
properly. Also, if reading the registers when both 
the ISTAT SIP and DIP bits may not be set, the 
SISTO and SISTl registers should be read before 
the DSTAT register to avoid missing a SCSI inter¬ 
rupt. For more information on interrupts, refer to 
Chapter 2, “Functional Description.” 

Bit 7 M/A (Initiator Mode: Phase Mis¬ 
match; Target Mode: SATN/ Active) 
In initiator mode, this bit is set if the SCSI 
phase asserted by the target does not match the 
instruction. The phase is sampled when SREQ/ 
is asserted by the target. In target mode, this 
bit is set when the SATN/ signal is asserted by 
the initiator. 

Bit 6 CMP (Function Complete) 

This bit is set when an arbitration only or full 
arbitration sequence has completed. 


Bit 5 SEL (Selected) 

This bit is set when the SYM53C875 is 
selected by another SCSI device. The Enable 
Response to Selection bit must have been set in 
the SCID register (and the RESPID register 
must hold the chip’s ID) for the SYM53C875 
to respond to selection attempts. 

Bit 4 RSL (Reselected) 

This bit is set when the SYM53C875 is rese¬ 
lected by another SCSI device. The Enable 
Response to Reselection bit must have been set 
in the SCID register (and the RESPID register 
must hold the chip’s ID) for the SYM53C875 
to respond to reselection attempts. 

Bit 3 SGE (SCSI Gross Error) 

This bit is set when the SYM53C875 encoun¬ 
ters a SCSI Gross Error Condition. The fol¬ 
lowing conditions can result in a SCSI Gross 
Error Condition: 

1. Data Underflow - the SCSI FIFO register 
was read when no data was present. 

2. Data Overflow - too many b 5 ^es were 
written to the SCSI FIFO or the 
synchronous offset caused the SCSI FIFO 
to be overwritten. 

3. Offset Underflow - the SYM53C875 is 
operating in target mode and a SACK/ 
pulse is received when the outstanding 
offset is zero. 

4. Offset Overflow - the other SCSI device 
sent a SREQ/ or SACK/ pulse with data 
which exceeded the maximum 
s 5 nichronous offset defined by the SXFER 
register. 

5. A phase change occurred with an 
outstanding synchronous offset when the 
SYM53C875 was operating as an initiator. 

6. Residual data in the Synchronous data 
FIFO - a transfer other than synchronous 
data receive was started with data left in the 
synchronous data FIFO. 
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Bit 2 UDC (Unexpected Disconnect) 

This bit is set when the SYM53C875 is operat¬ 
ing in initiator mode and the target device 
tmexpectedly disconnects from the SCSI bus. 
This bit is only valid when the SYM53C875 
operates in the initiator mode. When the 
SYM53C875 operates in low level mode, any 
disconnect will cause an interrupt, even a valid 
SCSI disconnect. This bit will also be set if a 
selection time-out occurs (it may occur before, 
at the same time, or stacked after the STO 
interrupt, since this is not considered an 
expected disconnect). 

Bit 1 RST (SCSI RST/ Received) 

This bit is set when the SYM53C875 detects 
an active SRST/ signal, whether the reset was 
generated external to the chip or caused by the 
Assert SRST/ bit in the SCNTLl register. This 
SYM53C875 SCSI reset detection logic is 
edge-sensitive, so that multiple interrupts will 
not be generated for a single assertion of the 
SRST/ signal. 

Bit 0 PAR (Parity Error) 

This bit is set when the SYM53C875 detects a 
parity error while receiving SCSI data. The 
Enable Parity Checking bit (bit 3 in the 
SCNTLO register) must be set for this bit to 
become active. The SYM53C875 always gen¬ 
erates parity when sending SCSI data. 


Register 43 (C3) 

SCSI Interrupt Status One (SISTl) 
Read Only 


RES 

RES 

RES 

RES 

RES 

STO 

GEN 

HTH 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

X 

X 

X 

0 

0 

0 


Reading the SISTl register returns the status of the 
various interrupt conditions, whether they are en¬ 
abled in the SIEN1 register or not. Each bit that is 
set indicates the corresponding condition has oc¬ 
curred. 

Reading the SISTl will clear the interrupt condi¬ 
tion. 

Bits 7-3 Reserved 

Bit 2 STO (Selection or Reselection 
Time-out) 

The SCSI device which the SYM53C875 was 
attempting to select or reselect did not respond 
within the programmed time-out period. See 
the description of the STIMEO register, bits 3- 
0, for more information on the time-out timer. 

Bit 1 GEN (General Purpose Timer 

Expired) 

This bit is set when the general purpose timer 
has expired. The time measured is the time 
between enabling and disabling of the timer. 
See the description of the STIMEl register, 
bits 3-0, for more information on the general 
purpose timer. 

Bit 0 HTH (Handshake-to-Handshake 

Timer Expired) 

This bit is set when the handshake-to-hand- 
shake timer has expired. The time measured is 
the SCSI Request to Request (target) or 
Acknowledge to Acknowledge (initiator) 
period. See the description of the STIMEO 
register, bits 7-4, for more information on the 
handshake-to-handshake timer. 
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Register 44 (C4) 

SCSI Longitudinal Parity (SLPAR) 
Read/Write 

The SLPAR register consists of two multiplexed 
bytes; other register bit settings determine what is 
displayed at this memory location at any given time. 
When bit 5 in the SCNTL2 (SLPMD) register is 
cleared^ the chip XORs the high and low bytes of 
the SLPAR register together to give a single-byte 
value which is displayed in the SLPAR register. If 
the SLPMD bit is set, then the SLPAR register 
shows either the high hytQ or the low byte of the 
SLPAR word. The SLPAR High Byte Enable bit, 
SCNTL2 bit 4, determines which byte of the 
SLPAR register is visible on the SLPAR register at 
any given time. If this bit is cleared, the SLPAR reg¬ 
ister contains the low byte of the SLPAR word; if it 
is set, the SLPAR register contains the high byte of 
the SLPAR word. 

This register performs a bytewise longitudinal par¬ 
ity check on all SCSI data received or sent through 
the SCSI core. If one of the bj^es received or sent 
(usually the last) is the set of correct even parity 
bits, SLPAR should go to zero (assuming it started 
at zero). As an example, suppose that the following 


three data bytes and one check byte are received 
from the SCSI bus (all signals are shown active 
high): 


Data Bytes 

Running SLPAR 


00000000 

1.11001100 

11001100 (XORofword 1) 

2.01010101 

10011001 (XOR of word 1 and 2) 

3,00001111 

10010110 (XORofword 1,2 and3) 
Even Parity >>>10010110 

4.10010110 

00000000 


A one in any bit position of the final SLPAR value 
would indicate a transmission error. 

The SLPAR register can also be used to generate 
the check bytes for SCSI send operations. If the 
SLPAR register contains all zeros prior to sending 
a block move, it will contain the appropriate check 
byte at the end of the block move. This byte must 
then be sent across the SCSI bus. 

Note: writing any value to this register resets it to 
zero. 

The longitudinal parity checks are meant to provide 
an added measure of SCSI data integrity and are 
entirely optional. This register does not latch SCSI 
selection/reselection IDs under any circumstances. 
The default value of this register is zero. 
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Register 45 (C5) 

SCSI Wide Residue (SWIDE) 

Read/Write 

After a wide SCSI data receive operation, this reg¬ 
ister will contain a residual data byte if the last byte 
received was never sent across the DMA bus. It 
represents either the first data byte of a subsequent 
data transfer, or it is a residue b 5 rte which should be 
cleared when an Ignore Wide Residue message is 
received. It may also be an overrun data byte. The 
power-up value of this register is indeterminate. 


Register 46 (C6) 

Memory Access Control (MACNTL) 
Read/Write 


TYP3 

TYP2 

TYP1 

TYPO 

DWR 

DRD 

PSCPT 

SCPTS 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 1 

1 

1 

0 

0 

0 

0 


Bits 7-4 TYP3-0 (Chip Type) 

These bits identify the chip t 3 q)e for software 
purposes. This data manual applies to devices 
that have these bits set to 07h. 

Bits 3 through 0 of this register are used to deter¬ 
mine if an external bus master access is to local or 
far memory. When bits 3 through 0 are set, the cor¬ 
responding access is considered local and the 
MAC/_TESTOUT pin is driven high. When these 
bits are clear, the corresponding access is to far 
memory and the MAC/_TESTOUT pin is driven 
low. This function is enabled after a Transfer Con¬ 
trol SCRIPTS instruction is executed. 


Bit 3 DWR (DataWR) 

This bit is used to define if a data write is con¬ 
sidered local memory access. 

Bit 2 DRD (DataRD) 

This bit is used to define if a data read is con¬ 
sidered local memory access. 

Bit 1 PSCPT (Pointer SCRIPTS) 

This bit is used to define if a pointer to a 
SCRIPTS indirect or table indirect fetch is 
considered local memory access. 

BitO SCPTS (SCRIPTS) 

This bit is used to define if a SCRIPTS fetch is 
considered local memory access. 
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Register 47 (C7) 

General Purpose Pin Control (GPCNTL) 
Read/Write 


ME 

FE 

RES 

GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

X 

0 

1 

1 

1 

1 


This register is used to determine if the pins con¬ 
trolled by the General Purpose register (GPREG) 
are inputs or outputs. Bits 4-0 in GPCNTL corre¬ 
spond to bits 4-0 in the GPREG register. When the 
bits are enabled as inputs, an internal pull-up is also 
enabled. 

Bit 7 Master Enable 

The internal bus master signal will be pre¬ 
sented on GPIO1 if this bit is set, regardless of 
the state of Bit 1 (GPI01_EN). 

Bit 6 Fetch Enable 

The internal op code fetch signal will be pre¬ 
sented on GPIOO if this bit is set, regardless of 
the state of Bit 0 (GPIOO_EN). 

Bit 5 Reserved 

Bits 4-2 GPI04_EN-GPI02_EN (GPIO 
Enable) 

General purpose control, corresponding to bits 
4-2 in the GPREG register and pins 60, 59, 
and 57. GPI04 powers up as a general purpose 
output, and GPI03-2 power up as general pur¬ 
pose inputs. 

Bits 1-0 GPI01_EN- GPIOO_EN (GPIO 
Enable) 

These bits power up set, causing the GPIOl 
and GPIOO pins to become inputs. Resetting 
these bits causes GPIO 1-0 to become outputs. 


Register 48 (C8) 

SCSI Timer Zero (STIMEO) 
Read /Write 


Hhin 

HTH 

HTH 

HRH 

SEL 

SEL 

SEL 

SEL 

■i 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-4 HTH (Handshake-to-Handshake 
Timer Period) 

These bits select the handshake-to-handshake 
time-out period, the maximum time between 
SCSI handshakes (SREQ/ to SREQ/ in target 
mode, or SACK/ to SACK/ in initiator mode). 
When this timing is exceeded, an interrupt is 
generated and the HTH bit in the SISTl regis¬ 
ter is set. The following table contains time-out 
periods for the Handshake-to-Handshake 
Timer, the Selection/Reselection Timer (bits 3- 
0), and the General Purpose Timer (STIMEl 
bits 3-0). For a more detailed explanation of 
interrupts, refer to Chapter 2, “Functional 
Description.” 


HTH 7-4, SEL 3-0, 

Minimum Time-out) 

GEN 3-0 

40 MHz/80 
MHz 

50 MHz 

0000 

Disabled 

Disabled 

0001 

125 MS 

100 MS 

0010 

250 MS 

200 MS 

0011 

500 MS 

400 MS 

0100 

1 ms 

800 MS 

0101 

2 ms 

1.6 ms 

0110 

4 ms 

3.2 ms 

0111 

8 ms 

6.4 ms 

1000 

16 ms 

12.8 ms 

1001 

32 ms 

25.6 ms 


These values mil be correct if the CCF bits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 
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HTH 7-4, SEL 3-0, 
GEN 3-0 

Minimum 

40 MHz/80 
MHz 

Time-out) 

50 MHz 

1010 

64 ms 

51.2 ms 

1011 

128 ms 

102.4 ms 

1100 

256 ms 

204.8 ms 

1101 

512 ms 

409.6 ms 

1110 

1.024 sec 

819,2 ms 

nil 

2.048 sec 

1.6384 sec 


These values will be correct if the CCF bits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 


Bits 3-0 SEL (Selection Time-Out) 

These bits select the SCSI selection/reselection 
time-out period. When this timing (plus the 
200 ps selection abort time) is exceeded, the 
STO bit in the SISTl register is set. For a 
more detailed explanation of interrupts, refer 
to Chapter 2, “Functional Description.” 


Register 49 (C9) 

SCSI Timer One (STIMEl) 
Read/Write 


RES 

HTHBA 

GENSF 

HTHSF 

GENS 

GEN2 

GEN1 

GENO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

0 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 HTHBA (Handshake-to-Handshake 

Timer Bus Activity Enable) 

Setting this bit causes this timer to begin test¬ 
ing for SCSI REQ/ACK activity as soon as 
SBSY/ is asserted, regardless of the agents par¬ 
ticipating in the transfer. 

Bits GENSF (General Purpose Timer 

Scale Factor) 

Setting this bit causes this timer to shift by a 
factor of 16. 


Minimum Time-out 

HTH 7-4, SEL 3-0, (50 MHz Ciock) 

GEN 3-0 



GENSF=0 

GENSF=1 

0000 

Disabled 

Disabled 

0001 

100 |as 

1.6 ms 

0010 

200 ps 

3.2 ms 

0011 

400 ps 

6.4 ms 

0100 

800 |Lis 

12.8 ms 

0101 

1.6 ms 

25.6 ms 

0110 

3.2 ms 

51.2 ms 

0111 

6.4 ms 

102.4 ms 

1000 

12.8 ms 

204.8 ms 

1001 

25.6 ms 

409.6 ms 

1010 

51.2 ms 

819.2 ms 

1011 

102.4 ms 

1.6 sec 

1100 

204.8 ms 

3.2 sec 

1101 

409.6 ms 

6.4 sec 

1110 

819.2 ms 

12.8 sec 

nil 

1.6 sec 

25.6 sec 


These values wiU be correct if the CCF bits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 
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Minimum Time-out 

HTH7-4,SEL3-0, (80 MHz Clock) 

GEN 3-0 

GENSF=0 GENSF=1 


0000 

Disabled 

Disabled 

0001 

125 ms 

2 ms 

0010 

250 ns 

4 ms 

0011 

500 ns 

8 ms 

0100 

1 ns 

16 ms 

0101 

2 ms 

32 ms 

0110 

4 ms 

64 ms 

0111 

8 ms 

128 ms 

1000 

16 ms 

256 ms 

1001 

32 ms 

512 ms 

1010 

64 ms 

1 sec 

1011 

128 ms 

2 sec 

1100 

256 ms 

4.1 sec 

1101 

512 ms 

8.2 sec 

1110 

1.024 sec 

16.4 sec 

nil 

2.048 sec 

32.8 sec 


These values will be correct if the CCF hits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 


the SISTl register is set. Refer to the table 
under STIMEO, bits 3-0, for the available 
time-out periods. 

Note: to reset a timer before it has expired and 
obtain repeatable delays, the time value 
must be written to zero first, and then 
written back to the desired value. This is 
also required when changing from one time 
value to another. See Chapter 2, 
^Tunctional Description,’^ for an 
explanation of how interrupts will be 
generated when the timers expire. 


Bit 4 HTHSF (Handshake to Handshake 
Timer Scale Factor) 

Setting this bit causes this timer to shift by a 
factor of 16. 

Bits 3-0 GEN3-0 (General Purpose Timer 
Period) 

These bits select the period of the general pur¬ 
pose timer. The time measured is the time 
between enabling and disabling of the timer. 
When this timing is exceeded, the GEN bit in 
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Register 4A (CA) 

Response ID Zero (RESPIDO) 
Read/Write 


Register 4B (CB) 

Response ID One(RESPlDl) 

Read/Write 

RESPIDO and RESPIDl contain the selection or 
reselection IDs. In other words, these two 8-bit reg¬ 
isters contain the ID that the chip responds to on 
the SCSI bus. Each bit represents one possible ID 
with the most significant bit of RESPIDl repre¬ 
senting ID 15 and the least significant bit of 
RESPIDO representing ID 0. The SCID register 
still contains the chip ID used during arbitration. 
The chip can respond to more than one ID because 
more than one bit can be set in the RESPIDl and 
RESPIDO registers. However, the chip can arbi¬ 
trate with only one ID value in the SCID register. 


Register 4C (CC) 

SCSI Test Zero (STESTO) 
Read Only 


SSAID3 

SSAID2 

SSAID1 

SSAIDO 

SLT 

ART 

soz 

SOM 

7 

6 

5 

4 

3 

2 

1 

0 

Defauit»> 

0 0 

0 

0 

0 

X 

1 

1 


Bits 7-4 SSAID (SCSI Selected As ID) 

These bits contain the encoded value of the 
SCSI ID that the SYM53C875 was selected or 
reselected as during a SCSI selection or rese¬ 
lection phase. These bits are read only and 
contain the encoded value of 0-15 possible IDs 
that could be used to select the SYM53C875. 
During a SCSI selection or reselection phase 
when a valid ID has been put on the bus, and 
the 53C875 responds to that ID, the “selected 
as” ID is written into these bits. These bits are 
used with the RESPID registers to allow 
response to multiple IDs on the bus. 

Bit 3 SLT (Selection Response Logic Test) 

This bit is set when the SYM53C875 is ready 
to be selected or reselected.This does not take 
into account the bus settle delay of 400 ns. 
This bit is used for functional test and fault 
purposes. 

Bit 2 ART (Arbitration Priority Encoder 
Test) 

This bit will always be set when the 
SYM53C875 exhibits the highest priority ID 
asserted on the SCSI bus during arbitration. It 
is primarily used for chip level testing, but it 
may be used during low level mode operation 
to determine if the SYM53C875 has won arbi¬ 
tration. 
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Bit 1 SOZ (SCSI Synchronous Offset 
Zero) 

This bit indicates that the cvirrent synchronous 
SREQ/SACK offset is zero. This bit is not 
latched and may change at any time. It is used 
in low level synchronous SCSI operations. 
When this bit is set, the SYM53C875, as an 
initiator, is waiting for the target to request 
data transfers. K the SYM53C875 is a target, 
then the initiator has sent the offset number of 
acknowledges. 

Bit 0 SOM (SCSI Synchronous Offset 
Maximum) 

This bit indicates that the current synchronous 
SREQ/SACK offset is the maximum specified 
by bits 3-0 in the SCSI Transfer register. This 
bit is not latched and may change at any time. 
It is used in low level synchronous SCSI opera¬ 
tions. When this bit is set, the SYM53C875, as 
a target, is waiting for the initiator to acknowl¬ 
edge the data transfers. If the SYM53C875 is 
an initiator, then the target has sent the offset 
number of requests. 


Register 4D (CD) 
SCSITest One (STESTl) 
Read/Write 


SCLK 

SISO 

RES 

RES 

RES 

RES 

RES 

RES 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

X 

X 

X 

X 

X 

X 


Bit 7 SCLK 

This bit, when set, will disable the external 
SCLK (SCSI Clock) pin, and the chip will use 
the PCI clock as the internal SCSI clock. If a 
transfer rate of 10 MB/s (or 20 MB/s on a wide 
SCSI bus) is to be achieved on the SCSI bus, 
this bit must be reset and at least a 40 MHz 
external SCLK must be provided. 

Bit 6 SISO (SCSI Isolation Mode) 

This bit allows the SYM53C875 to put the 
SCSI bi-directional and input pins into a low 
power mode when the SCSI bus is not in use. 
When this bit is set, the SCSI bus inputs are 
logically isolated from the SCSI bus. 

Bits 5-4 Reserved 

Bit 3 SCLK Doubler Enable (DBLEN) 

Set this bit to bring the SCSI clock doubler out 
of the powered-down state. The default value 
of this bit is clear (SCSI clock doubler powered 
down). Set bit 2 after setting this bit, to double 
the SCLK frequency. 

Bit 2 SCLK Doubler Select (DBLSEL) 

Set this bit after powering up the SCSI clock 
doubler to double The SCLK frequency. This 
bit has no effect unless bit 3 is set. 

Bitsl-0 Reserved 
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Doubling the SCSI CLK Frequency 

The SYM53C875 SCSI clock doubler doubles a 
40 MHz SCSI clock, increasing the frequency to 
80 MHz. Follow these steps to use the clock dou¬ 
bler: 

1. Set the SCLK Doubler Enable bit 
(STESTl, bit 3) 

2. Wait 20 ps 

3. Halt the SCSI clock by setting the Halt 
SCSI Clock bit (STEST3 bit 5) 

4. Set the clock conversion factor using the 
SCF and CCF fields in the SCNTL3 
register 

5. Set the SCLK Doubler Select bit 
(STESTl, bit2) 

6. Clear the Halt SCSI Clock bit 


Register 4E (CE) 

SCSI Test Two (STEST2) 
Read/Write 


SCE 

ROF 

DIF 

SLB 

SZM 

AWS 

EXT 

LOW 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 SCE (SCSI Control Enable) 

This bit, when set, allows all SCSI control and 
data lines to be asserted through the SOCL 
and SODL registers regardless of whether the 
SYM53C875 is configured as a target or initia¬ 
tor. 

Note: this bit should not be set during normal 
operation, since it could cause contention 
on the SCSI bus. It is included for 
diagnostic purposes only. 

Bit 6 ROF (Reset SCSI Offset) 

Setting this bit clears any outstanding s 5 nichro- 
nous SREQ/SACK offset.This bit should be 
set if a SCSI gross error condition occurs, to 
clear the offset when a synchronous transfer 
does not complete successfully. The bit auto¬ 
matically clears itself after resetting the S 5 m- 
chronous offset. 

Bit 5 DIF (SCSI Differential Mode) 

Setting this bit allows the SYM53C875 to 
interface properly to external differential trans¬ 
ceivers. Its only real effect is to tri-state the 
SBSY/, SSEL/, and SRST/ pads so that they 
can be used as pure inputs. Clearing this bit 
enables single-ended mode operation. This bit 
should be set in the initialization routine if the 
differential pair interface is used. 

Bit 4 SLB (SCSI Loopback Mode) 

Setting this bit allows the SYM53C875 to per¬ 
form SCSI loopback diagnostics. That is, it 
enables the SCSI core to simultaneously per¬ 
form as both initiator and target. 
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Bit 3 SZM (SCSI High-Impedance Mode) 

Setting this bit places all the open-drain 
48 mA SCSI drivers into a high-impedance 
state. This is to allow internal loopback mode 
operation without affecting the SCSI bus. 

Bit 2 AWS (Always Wide SCSI) 

When this bit is set, all SCSI information 
transfers will be done in 16-bit wide mode. 
This includes data, message, command, status 
and reserved phases. This bit should normally 
be deasserted since 16-bit wide message, com¬ 
mand, and status phases are not supported by 
the SCSI specifications. 

Bit 1 EXT (Extend SREQ/SACK Filter- 

ing) 

Symbios TolerANT SCSI receiver technology 
includes a special digital filter on the SREQ/ 
and SACK/ pins which will cause glitches on 
deasserting edges to be disregarded. Setting 
this bit will increase the filtering period from 
30ns to 60ns on the deasserting edge of the 
SREQ/ and SACK/ signals. 

Note: this bit must never be set during fast SCSI 
(greater than 5M transfers per second) 
operations, because a valid assertion could 
be treated as a glitch. 

Note: this bit does not affect the filtering period 
when the Fast-20 Enable bit in the 
SCNTL3 register is set. When the 
SYM53C875 is executing UltraSCSI 
transfers, the filtering period is 
automatically set at 15 ns. 

Bit 0 LOW (SCSI Low level Mode) 

Setting this bit places the SYM53C875 in low 
level mode. In this mode, no DMA operations 
occur, and no SCRIPTS execute. Arbitration 
and selection may be performed by setting the 
start sequence bit as described in the SCNTLO 
register. SCSI bus transfers are performed by 
manually asserting and polling SCSI signals. 
Clearing this bit allows instructions to be exe¬ 
cuted in SCSI SCRIPTS mode. 

Note: it is not necessary to set this bit for access 
to the SCSI bit-level registers (SODL, 

SB CL, and input registers). 
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Register 4F (CF) 

SCSI Test Three (STEST3) 
Read/Write 


TE 

STR 

HSC 

DSI 

S16 

UM 

CSF 

STW 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 TE (TolerANT Enable) 

Setting this bit enables the active negation por¬ 
tion of Symbios TolerANT technology. Active 
negation causes the SCSI Request, Acknowl¬ 
edge, Data, and Parity signals to be actively 
deasserted, instead of relying on external pull- 
ups, when the SYM53C875 is driving these 
signals. Active deassertion of these signals will 
occur only when the SYM53C875 is in an 
information transfer phase. When operating in 
a differential environment or at fast SCSI tim¬ 
ings, TolerANT Active negation should be 
enabled to improve setup and deassertion 
times. Active negation is disabled after reset or 
when this bit is cleared. For more information 
on Symbios TolerANT technology, refer to 
Chapter 1. 

Note: this bit must be set if the Enable Fast 20 bit 
in SCNTL3 is set. 

Bit 6 STR (SCSI FIFO Test Read) 

Setting this bit places the SCSI core into a test 
mode in which the SCSI FIFO can be easily 
read. Reading the least significant byte of the 
SODL register will cause the FIFO to unload. 
The functions are summarized in the table 
below. 


Register 

Name 

Register 

Operation 

FiFO Bits 

FiFO 

Function 

SODL 

Read 

15-0 

Unload 

SODLO 

Read 

7-0 

Unload 

SODLl 

Read 

15-8 

None 


Bit 5 HSC (Halt SCSI Clock) 

Asserting this bit causes the internal divided 
SCSI clock to come to a stop in a glitchless 
manner. This bit may be used for test purposes 
or to lower Ij^j) during a power down mode. 
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This bit is used when the SCSI clock doubler is the SCSI FIFO pointers, the SIDL, SODL, 

operating. For additional information on the and SODR fiill bits in the SSTATO and 

clock doubler, please see Chapter 2. SSTAT2 are cleared. 


Bit 4 DSI (Disable Single Initiator 
Response) 

If this bit is set, the SYM53C875 will ignore all 
bus-initiated selection attempts that employ 
the single-initiator option from SCSI-1. In 
order to select the SYM53C875 while this bit 
is set, the SYM53C875’s SCSI ID and the ini¬ 
tiator’s SCSI ID must both be asserted. This 
bit should be asserted in SCSI-2 systems so 
that a single bit error on the SCSI bus will not 
be interpreted as a single initiator response. 

Bit 3 S16 (16-bit System) 

If this bit is set, all devices in the SCSI system 
implementation are assumed to be 16 bits. This 
causes the SYM to always check the parity bit 
for SCSI IDs 15-8 during bus-initiated selec¬ 
tion or reselection, assuming parity checking 
has been enabled. If an 8-bit SCSI device 
attempts to select the SYM53C875 while this 
bit is set, the SYM53C875 will ignore the 
selection attempt, because the parity bit for 
IDs 15-8 will be undriven. See the description 
of the Enable Parity Checking bit in the 
SCNTLO register for more information. 

Bit 2 TTM (Timer Test Mode) 

Asserting this bit facilitates testing of the selec¬ 
tion time-out, general purpose, and hand- 
shake-to-handshake timers by greatly reducing 
all three time-out periods. Setting this bit starts 
all three timers and if the respective bits in the 
SIENl register are asserted, the SYM53C875 
will generate interrupts at time-out. This bit is 
intended for internal manufacturing diagnosis 
and should not be used. 


Bit 0 STW (SCSI FIFO Test Write) 

Setting this bit places the SCSI core into a test 
mode in which the FIFO can easily be read or 
written. While this bit is set, writes to the least 
significant byte of the SODL register will cause 
the entire word contained in this register to be 
loaded into the FIFO. Writing the least signifi¬ 
cant byte of the SODL register will cause the 
FIFO to load. These functions are summarized 
in the table below: 


Register 

Name 

Register 

Operation 

FIFO Bits 

FIFO 

Function 

SODL 

Write 

15-0 

Load 

SODLO 

Write 

7-0 

Load 

SODLl 

Write 

15-8 

None 


Bit 1 CSF (Clear SCSI FIFO) 

Setting this bit will cause the “full flags” for the 
SCSI FIFO to be cleared.This empties the 
FIFO. This bit is self-resetting. In addition to 
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Register 50-51 (DO-Dl) 

SCSI Input Data Latch (SIDL) 

Read Only 

This register is used primarily for diagnostic testing, 
programmed I/O operation, or error recovery. Data 
received from the SCSI bus can be read from this 
register. Data can be written to the SODL register 
and then read back into the SYM53C875 by read¬ 
ing this register to allow loopback testing. When re¬ 
ceiving SCSI data, the data will flow into this 
register and out to the host FIFO. This register dif¬ 
fers from the SBDL register; SIDL contains latched 
data and the SBDL always contains exactly what is 
currently on the SCSI data bus. Reading this regis¬ 
ter causes the SCSI parity bit to be checked, and 
will cause a parity error interrupt if the data is not 
valid. The power-up values are indeterminate. 


Registers 54-55 (D4-D5) 

SCSI Output Data Latch (SODL) 
Read/Write 

This register is used primarily for diagnostic testing 
or programmed I/O operation. Data written to this 
register is asserted onto the SCSI data bus by set¬ 
ting the Assert Data Bus bit in the SCNTLl regis¬ 
ter. This register is used to send data via 
programmed I/O. Data flows through this register 
when sending data in any mode. It is also used to 
write to the synchronous data FIFO when testing 
the chip. The power-up value of this register is in¬ 
determinate. 
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Registers 58-59 (D8-D9) 

SCSI Bus Data Lines (SBDL) 

Read Only 

This register contains the SCSI data bus status. 
Even though the SCSI data bus is active low, these 
bits are active high. The signal status is not latched 
and is a true representation of exactly what is on the 
data bus at the time the register is read. This regis¬ 
ter is used when receiving data via programmed 
I/O. This register can also be used for diagnostic 
testing or in low level mode. The power-up value of 
this register is indeterminate. 


Registers 5C-5F (DC-DF) 

Scratch Register B (SCRATCHB) 
(Read/Write) 

This is a general purpose user definable scratch pad 
register. Apart firom CPU access, only Register 
Read/Write and Memory Moves directed at the 
SCRATCH register will alter its contents. The 
SYM53C875 cannot fetch SCRIPTS instructions 
firom this location.When bit 3 in the CTEST2 reg¬ 
ister is set, this register contains the base address for 
the 4 KB internal RAM. Setting CTEST2 bit 3 
only causes the base address to appear in the 
SCRATCHB register; any information that was 
previously in the register will remain intact. Any 
writes to this register while the bit is set will pass 
through to the actual SCRATCHB register. The 
power-up values are indeterminate. 
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Registers 60h-7Fh (EOh-FFh) 

Scratch Registers C-J 
(SCRATCHC-SCRATCHJ) 

ReadASf^rite 

These registers are general-purpose scratch regis¬ 
ters for user-defined functions. The SYM53C875 
cannot fetch SCRIPTS instructions from this loca- 
tion.The power up value of these registers is inde¬ 
terminate. 
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Chapter 6 

Instruction Set of the I/O Processor 


After power up and initialization of the 
SYM53C8755 the chip may be operated in the low 
level register interface mode, or using SCSI 
SCRIPTS. 

With the low level register interface, the user has 
access to the DMA control logic and the SCSI bus 
control logic. An external processor has access to 
the SCSI bus signals and the low level DMA sig¬ 
nals, which allows creation of complicated board 
level test algorithms. The low level interface is use¬ 
ful for backward compatibility with SCSI devices 
that require certain unique timings or bus 
sequences to operate properly. Another feature 
allowed at the low level is loopback testing. In 
loopback mode, the SCSI core can be directed to 
talk to the DMA core to test internal data paths all 
the way out to the chip’s pins. 


SCSI SCRIPTS 

To operate in the SCSI SCRIPTS mode, the 
SYM53C875 requires only a SCRIPTS start 
address.The start address must be at a longword 
(four byte) boundary. This will align all the follow¬ 
ing SCRIPTS at a longword boundary since all 
SCRIPTS are 8 or 12 bytes long. 

Instructions are fetched until an interrupt instruc¬ 
tion is encountered, or until an unexpected event 
(such as a hardware error) causes an interrupt to 
the external processor. 

Once an interrupt is generated, the SYM53C875 
halts all operations until the interrupt is serviced. 
Then, the start address of the next SCRIPTS 
instruction may be written to the DMA SCRIPTS 
Pointer register to restart the automatic fetching 
and execution of instructions. 


The SCSI SCRIPTS mode of execution allows the 
SYM53C875 to make decisions based on the sta¬ 
tus of the SCSI bus, which off-loads the micropro¬ 
cessor from servicing the numerous interrupts 
inherent in I/O operations. 

Given the rich set of SCSI-oriented features 
included in the instruction set, and the ability to 
re-enter the SCSI algorithm at any point, this high 
level interface is all that is required for both normal 
and exception conditions. Switching to low level 
mode for error recovery should never be required. 
The following types of SCRIPTS instructions are 
implemented in the SYM53C875: 

■ Block Move—used to move data between the 
SCSI bus and memory 

■ I/O or Read/Write—causes the SYM53C875 
to trigger common SCSI hardware sequences, 
or to move registers 

■ Transfer Control—allows SCRIPTS 
instructions to make decisions based on real 
time SCSI bus conditions 

■ Memory Move—causes the SYM53C875 to 
execute block moves between different parts of 
main memory 

■ Load and Store—provides a more efficient way 
to move data to/from memory from/to an 
internal register in the chip without using the 
Memory Move instruction 

Each instruction consists of two or three 32-bit 
words. The first 32-bit word is always loaded into 
the DCMD and DBC registers, the second into 
the DSPS register. The third word, used only by 
Memory Move instructions, is loaded into the 
TEMP shadow register. In an indirect I/O or Move 
instruction, the first two 32-bit op code fetches will 
be followed by one or two more 32-bit fetch cycles. 
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Sample Operation 

The following example describes execution of a 
SCRIPTS instruction. This sample operation is for 
a Block Move instruction. 

1. The host CPU, through programmed I/O, 
gives the DMA SCRIPTS Pointer (DSP) 
register (in the Operating Register file) the 
starting address in main memory that points to 
a SCSI SCRIPTS program for execution. 

2. Loading the DSP register causes the 
SYM53C875 to fetch its first instruction at the 
address just loaded. This will be from main 
memory or the internal RAM, depending on 
the address. 

3. The SYM53C875 typically fetches two 
longwords (64 bits) and decodes the high order 
byte of the first longword as a SCRIPTS 
instruction. If the instruction is a Block Move, 
the lower three bytes of the first longword are 
stored and interpreted as the number of bytes 
to be moved. The second longword is stored 
and interpreted as the 32-bit beginning address 
in main memory to which the move is directed. 

4. For a SCSI send operation, the SYM53C875 
waits until there is enough space in the DMA 
FIFO to transfer a programmable size block of 
data. For a SCSI receive operation, it waits 
until enough data is collected in the DMA 
FIFO for transfer to memory. At this point, the 
SYM53C875 requests use of the PCI bus 
again to transfer the data. 

5. When the SYM53C875 is granted the PCI 
bus, it will execute (as a bus master) a burst 
transfer (programmable size) of data, 
decrement the internally stored remaining bjrte 
count, increment the address pointer, and then 
release the PCI bus.The SYM53C875 stays off 
the PCI bus until the FIFO can again hold (for 
a write) or has collected (for a read) enough 
data to repeat the process. 

The process repeats until the internally stored byte 
count has reached zero. The SYM53C875 releases 
the PCI bus and then performs another SCRIPTS 


instruction fetch cycle, using the incremented 
stored address maintained in the DMA SCRIPTS 
Pointer register. Execution of SCRIPTS instruc¬ 
tions continues until an error condition occurs or 
an interrupt SCRIPTS instruction is received. At 
this point, the SYM53C875 interrupts the host 
CPU and waits for further servicing by the host 
system. It can execute independent Block Move 
instructions specifying new byte counts and start¬ 
ing locations in main memory. In this manner, the 
SYM53C875 performs scatter/gather operations 
on data without requiring help from the host pro¬ 
gram, generating a host interrupt, or requiring an 
external DMA controller to be programmed. 
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System Processor 


System Memory 
(or Internal RAM) 


SCSI Initiator Write Example 

select ATN 0, alt_addr 

move 1, identify msg buf, when MSG_OUTj 
move 6, cmd_buf, when CMD 
move 512, data_buf, when DATA_OUT 
move 1, stat_m_buf, when STATUS 
move 1, msg:_m_buf, when MSG_IN 
move SCNTL2 & 7F to SCNTL2 
clear ACK 
wait disconnect aJt2 

int 10_ 


Data Structure 
Message Buffer 
Co mman d Buffer 
Data Buffer 
Status Buffer 


s 

y 

s 

t 

e “ 
m 



Write DSP 


Fetch 

SCRIPTS 


SYM53C875 

SCSI 


Bus 


(Data will not be fetched 
across system bus If 
internal RAM is enabled) 


Figure 6-1; SCRIPTS Overview 
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Block Move Instructions 

For Block Move instructions, bits 5 and 4 (SIOM 
and DIOM) in the DMODE register determine 
whether the source/destination address resides in 
memory or I/O space. When data is being moved 
onto the SCSI bus, SIOM controls whether that 
data comes from I/O or memory space. When data 
is being moved off of the SCSI bus, DIOM con¬ 
trols whether that data goes to FO or memory 
space. 


First Dword 

Bits 31-30 Instruction Type-Block Move 
Bit 29 Indirect Addressing 

When this bit is cleared, user data is moved to 
or from the 32-bit data start address for the 
Block Move instruction. The value is loaded 
into the chip^s address register and incre¬ 
mented as data is transferred.The address of 
the data to be moved is in the second dword of 
this instruction. 

When set, the 32-bit user data start address for 
the Block Move is the address of a pointer to 
the actual data buffer address.The value at the 
32-bit start address is loaded into the chip’s 
DNAD register via a third longword fetch (4- 
byte transfer across the host computer bus). 

Direct 

The byte count and absolute address are as 


follows. 


Command 

Byte Count 

Address of Data 


Indirect 

Use the fetched byte count, but fetch the data 
address from the address in the instruction. 


Once the data pointer address is loaded, it is 
executed as when the chip operates in the 
direct mode. This indirect feature allows a 
table of data buffer addresses to be specified. 
Using the NCR SCSI SCRIPTS compiler, the 
table offset is placed in the script at compile 
time. Then at the actual data transfer time, the 
offsets are added to the base address of the 
data address table by the external processor. 
The logical I/O driver builds a structure of 
addresses for an I/O rather than treating each 
address individually. This feature makes it pos¬ 
sible to locate SCSI SCRIPTS in a PROM. 

Note: indirect and table indirect addressing 

cannot be used simultaneously; only one 
addressing method may be used at a time. 

Bit 28 Table Indirect 

When this bit is set, the 24-bit signed value in 
the start address of the move is treated as a rel¬ 
ative displacement from the value in the DSA 
register. Both the transfer count and the 
source/destination address are fetched from 
this address. 

Use the signed integer offset in bits 23-0 of the 
second four bytes of the instruction, added to 
the value in the DSA register, to fetch first the 
byte count and then the data address. The 
signed value is combined with the data struc¬ 
ture base address to generate the physical 
address used to fetch values from the data 
structure. Sign-extended values of all ones for 
negative values are allowed, but bits 31-24 are 
ignored. 


Command 

Not Used 

Don’t Care 

Table Offset 


Note: indirect and table indirect addressing 

cannot be used simultaneously; only one 
addressing method may be used at a time. 


Command 

Byte Count 

Address of Pointer to Data 
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4— DCMD Register —► 
31 30 29 28 27 26 25 24 


^-DBC Register-► 

23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


■I/O 
C/D 
MSG/ 

'— Op Code 

‘—Table Indirect Addressing 
'— Indirect Addressing (53C700 compatible) 
'— 0 - Instruction Type - Block Move 
'— 0 - Instruction Type - Block Move 


I 


24-bit Block Move byte counter 


DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 6-2: Block Move Instruction Register 


Prior to the start of an I/O, the Data Structure 
Base Address register (DSA) should be loaded 
with the base address of the I/O data structure* 
The address may be any address on a long 
word boundary* 

After a Table Indirect op code is fetched, the 
DSA is added to the 24-bit signed offset value 
from the op code to generate the address of the 
required data; both positive and negative off¬ 
sets are allowed* A subsequent fetch from that 
address brings the data values into the chip. 
For a MOVE instruction, the 24-bit hytc 
count is fetched from system memory. Then 
the 32-bit physical address is brought into the 
SYM53C875. Execution of the move begins at 
this point. 


SCRIPTS can directly execute operating sys¬ 
tem I/O data structures, saving time at the 
beginning of an I/O operation. The I/O data 
structure can begin on any longword boundary 
and may cross system segment boundaries. 

There are two restrictions on the placement of 
pointer data in system memory: the eight bytes 
of data in the MOVE instruction must be con¬ 
tiguous, as shown below; and indirect data 
fetches are not available during execution of a 
Memory-to-Memory DMA operation. 


00 

Byte Count 

Physical Data Address 
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Instruction Set of the I/O Processor 

Block Move Instructions 


Bit 27 Op Code 

This 1-bit field defines the instruction to be 
executed as a block move (MOVE). 


Target Mode 


OPC 

Instruction Defined 

0 

MOVE 

1 

CHMOV 


1. The SYM53C875 verifies that it is connected 
to the SCSI bus as a target before executing 
this instruction. 

2. The SYM53C875 asserts the SCSI phase 
signals (SMSG/, SC_D /5 and SI_0/) as defined 
by the Phase Field bits in the instruction. 

3. If the instruction is for the command phase, 
the SYM53C875 receives the first command 
byte and decodes its SCSI Group Code. 

a) If the SCSI Group Code is either Group 0, 
Group 1, Group 2, or Group 5, and if the 
Vendor Unique Enhancement 1 (VUEl) 
bit (SCNTL2 bit 1) is clear, then the 
SYM53C875 overwrites the DBG register 
with the length of the Command 
Descriptor Block: 6, 10, or 12 bytes. 

b) If the Vendor Unique Enhancement 1 
(VUEl) bit (SCNTL2 bit 1) is set, the 
SYM53C875 receives the number of bj^es 
in the byte count regardless of the group 
code. 

c) If the Vendor Unique Enhancement 1 bit is 
clear and group code is vendor unique, the 
SYM53C875 receives the number of bytes 
in the count regardless of the group code. 

d) If any other Group Code is received, the 
DBG register is not modified and the 
SYM53C875 will request the number of 
bytes specified in the DBG register. If the 
DBG register contains OOOOOOh, an illegal 
instruction interrupt is generated. 


4. The SYM53C875 transfers the number of 
b57tes specified in the DBG register starting at 
the address specified in the DNAD register. If 
the Op Code bit is set and a data transfer ends 
on an odd byte boimdary, the SYM53C875 
will store the last b 5 ^e in the SCSI Wide 
Residue Data Register during a receive 
operation. This byte will be combined with the 
first byte firom the subsequent transfer so that a 
wide transfer can be completed. 

5. If the SATN/ signal is asserted by the initiator 
or a parity error occurred during the transfer, 
the transfer can optionally be halted and an 
interrupt generated. The Disable Halt on 
Parity Error or ATN bit in the SCNTLl 
register controls whether the SYM53C875 will 
halt on these conditions immediately, or wait 
until completion of the current Move. 


Initiator Mode 


OPC 

Instruction Defined 

0 

CHMOV 

1 

MOVE 


1. The SYM53C875 verifies that it is connected 
to the SCSI bus as an initiator before executing 
this instruction. 

2. The SYM53C875 waits for an unserviced 
phase to occur. An unserviced phase is defined 
as any phase (with SREQ/ asserted) for which 
the SYM53C875 has not yet transferred data 
by responding with a SACK/. 

3. The SYM53C875 compares the SCSI phase 
bits in the DCMD register with the latched 
SCSI phase lines stored in the SSTATl 
register. These phase lines are latched when 
SREQ/ is asserted. 

4. If the SCSI phase bits match the value stored 
in the SSTATl register, the SYM53C875 will 
transfer the number of b 5 ^es specified in the 
DBG register starting at the address pointed to 
by the DNAD register. If the op code bit is 
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Instruction Set of the 1/0 Processor 

Block Move Instructions 


cleared and a data transfer ends on an odd byte 
boundary, the SYM53C875 will store the last 
byte in the SCSIWide Residue Data Register 
during a receive operation, or in the SCSI 
Output Data Latch Register during a send 
operation. This bjrte will be combined with the 
first byte from the subsequent transfer so that a 
wide transfer can be completed. 

5. If the SCSI phase bits do not match the value 
stored in the SSTATl register, the 
SYM53C875 generates a phase mismatch 
interrupt and the instruction is not executed. 

6. During a Message Out phase, after the 
SYM53C875 has performed a select with 
Attention (or SATN/ has been manually 
asserted with a Set ATN instruction), the 
SYM53C875 will deassert SATN/ during the 
final SREQ/SACK handshake. 

7. When the SYM53C875 is performing a block 
move for Message In phase, it will not deassert 
the SACK/ signal for the last SREQ/SACK 
handshake. The SACK signal must be cleared 
using the Clear SACK I/O instruction. 

Bits 26-24 SCSI Phase 

This 3-bit field defines the desired SCSI infor¬ 
mation transfer phase. When the SYM53C875 
operates in initiator mode, these bits are com¬ 
pared with the latched SCSI phase bits in the 
SSTATl register. When the SYM53C875 
operates in target mode, the SYM53C875 
asserts the phase defined in this field. The fol¬ 
lowing table describes the possible combina¬ 
tions and the corresponding SCSI phase. 


Bits 23-0 Transfer Counter 

This 24-bit field specifies the number of data 
b 5 rtes to be moved between the SYM53C875 
and system memory. The field is stored in the 
DEC register. When the SYM53C875 trans¬ 
fers data to/from memory, the DEC register is 
decremented by the number of bytes trans¬ 
ferred. In addition, the DNAD register is 
incremented by the number of bj^es trans¬ 
ferred. This process is repeated until the DEC 
register has been decremented to zero. At that 
time, the SYM53C875 fetches the next 
instruction. 

If bit 28 is set, indicating table indirect 
addressing, this field is not used. The byte 
count is instead fetched from a table pointed to 
by the DSA register. 


Second Dword 

Bits 31-0 Start Address 

This 32-bit field specifies the starting address 
of the data to be moved to/from memory. This 
field is copied to the DNAD register. When the 
SYM53C875 transfers data to or from mem¬ 
ory, the DNAD register is incremented by the 
number of bj^ies transferred. 

When bit 29 is set, indicating indirect address¬ 
ing, this address is a pointer to an address in 
memory that points to the data location. When 
bit 28 is set, indicating table indirect address¬ 
ing, the value in this field is an offset into a 
table pointed to by the DSA. The table entry 
contains b 5 ^e count and address information. 


MSG 

C/D 

I/O 

SCSI Ph3S6 

0 

0 

0 

Data out 

0 

0 

1 

Data in 

0 

1 

0 

Command 

0 

1 

1 

Status 

1 

0 

0 

Reserved out 

1 

0 

1 

Reserved in 

1 

1 

0 

Message out 

1 

1 

1 

Message in 


SYM53C875 Data Manual 


6-7 



Instruction Set of the I/O Processor 

I/O Instructions 


I/O Instructions 


First Dword 

Bits 31-30 Instruction Type - I/O Instruction 
Bits 29-27 Op Code 

The following Op Code bits have different 
meanings, depending on whether the 
SYM53C875 is operating in initiator or target 
mode. Note: Op Code selections 101-111 are 
considered Read/Write instructions, and are 
described in that section. 


Target Mode 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Reselect 

0 

0 

1 

Disconnect 

0 

1 

0 

Wait Select 

0 

1 

1 

Set 

1 

0 

0 

Clear 


Reselect Instruction 

1. The SYM53C875 arbitrates for the SCSI bus 
by asserting the SCSI ID stored in the SCID 
register. If the SYM53C875 loses arbitration, 
then it tries again during the next available 
arbitration cycle without reporting any lost 
arbitration status. 

2. If the SYM53C875 wins arbitration, it 
attempts to reselect the SCSI device whose ID 
is defined in the destination ID field of the 
instruction. Once the SYM53C875 has won 
arbitration, it fetches the next instruction fi:om 
the address pointed to by the DSP register. 
Therefore, the SCRIPTS can move on to the 
next instructions before the reselection has 
completed. It will continue executing 
SCRIPTS until a SCRIPT that requires a 
response fi:om the initiator is encountered. 

3. If the SYM53C875 is selected or reselected 
before winning arbitration, it fetches the next 


instruction firom the address pointed to by the 
32-bit jump address field stored in the DNAD 
register.The SYM53C875 should manually be 
set to initiator mode if it is reselected, or to 
target mode if it is selected. 

Disconnect Instruction 

The SYM53C875 disconnects firom the SCSI bus 
by deasserting all SCSI signal outputs. 

Wait Select Instruction 

1. If the SYM53C875 is selected, it fetches the 
next instruction firom the address pointed to by 
the DSP register. 

2. If reselected, the SYM53C875 fetches the next 
instruction firom the address pointed to by the 
32-bit jump address field stored in the DNAD 
register.The SYM53C875 should manually be 
set to initiator mode when reselected. 

3. If the CPU sets the SIGP bit in the ISTAT 
register, the SYM53C875 will abort the Wait 
Select instruction and fetch the next 
instruction firom the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. 

Set Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits in the SOCL register are set. SACK/ 
or SATN/ should not be set except for testing pur¬ 
poses. When the target bit is set, the corresponding 
bit in the SCNTLO register is also set. When the 
carry bit is set, the corresponding bit in the Arith¬ 
metic Logic Unit (ALU) is set. 

Note: None of the signals are set on the SCSI bus 
in target mode. 

Clear Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits are cleared in the SOCL register. 
SACK/ or SATN/ should not be set except for test¬ 
ing purposes. When the target bit is set, the corre¬ 
sponding bit in the SCNTLO register is cleared. 
When the carry bit is set, the corresponding bit in 
the ALU is cleared. 

Note: None of the signals are reset on the SCSI 
bus in target mode. 
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I/O Instructions 





T T 

RES RES 


▼ 

RES 


SeVCIearATN/ 
Set/Clear ACK/ 

— Set/Clear Target Mode 
— Set/Clear Carry 

— Encoded Destination ID 0 
— Encoded Destination ID 1 
— Encoded Destination ID 2 
— Encoded Destination ID 3 
— Reserved 
— Reserved 
— Reserved 
— Reserved 
— Select with ATN/ 

— Table Indirect Mode 
— Relative Address Mode 
— Op Code bit 0 
— Op Code bit 1 
— Op Code bit 2 
— 1 - Instruction Type - I/O 
— 0 - Instruction Type - I/O 


Second 32-bit word of the I/O instruction 
DSPSRegister 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



32-bit Jump Address 


Figure 6-3: I/O Instruction Register 
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Instruction Set of the I/O Processor 

I/O Instructions 


Initiator Mode 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Select 

0 

0 

1 

Wait Disconnect 

0 

1 

0 

Wait Reselect 

0 

1 

1 

Set 

1 

0 

0 

Clear 


Select Instruction 

1. The SYM53C875 arbitrates for the SCSI bus 
by asserting the SCSI ID stored in the SCID 
register. If the SYM53C875 loses arbitration, 
it tries again during the next available 
arbitration cycle without reporting any lost 
arbitration status. 

2. If the SYM53C875 wins arbitration, it 
attempts to select the SCSI device whose ID is 
defined in the destination ID field of the 
instruction. Once the SYM53C875 has won 
arbitration, it fetches the next instruction fi:om 
the address pointed to by the DSP register. 
Therefore, the scripts can move to the next 
instruction before the selection has completed. 
It will continue executing SCRIPTS until a 
SCRIPT that requires a response from the 
target is encountered. 

3. If the SYM53C875 is selected or reselected 
before winning arbitration, it fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. The SYM53C875 should manually be 
set to initiator mode if it is reselected, or to 
target mode if it is selected. 

4. If the Select with SATN/ field is set, the 
SATN/ signal is asserted during the selection 
phase. 

Wait Disconnect Instruction 

The SYM53C875 waits for the target to perform a 

"Uegal” disconnect from the SCSI bus. A 'UegaF’ 

disconnect occurs when SBSY/ and SSEL/ are 


inactive for a minimum of one Bus Free delay (400 
ns), afl:er the SYM53C875 has received a Discon¬ 
nect Message or a Command Complete Message. 

Wait Reselect Instruction 

1. If the SYM53C875 is selected before being 
reselected, it fetches the next instruction fi:om 
the address pointed to by the 32-bit jump 
address field stored in the DNAD register. The 
SYM53C875 should be manually set to target 
mode when selected. 

2. If the SYM53C875 is reselected, it fetches the 
next instruction from the address pointed to by 
the DSP register. 

3. If the CPU sets the SIGP bit in the ISTAT 
register, the SYM53C875 will abort the Wait 
Reselect instruction and fetch the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. 

Set Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits in the SOCL register are set. When 
the target bit is set, the corresponding bit in the 
SCNTLO register is also set. When the carry bit is 
set, the corresponding bit in the ALU is set. 

Clear Instruction 

When the SACK/or SATN/ bits are set, the corre¬ 
sponding bits are cleared in the SOCL register. 
When the target bit is set, the corresponding bit in 
the SCNTLO register is cleared. When the carry 
bit is set, the corresponding bit in the ALU is 
cleared. 

Bit 26 Relative Addressing Mode 

When this bit is set, the 24-bit signed value in 
the DNAD register is used as a relative dis¬ 
placement from the current DSP address. This 
bit should only be used in conjunction with the 
Select, Reselect, Wait Select, and Wait Reselect 
instructions. The Select and Reselect instruc¬ 
tions can contain an absolute alternate jump 
address or a relative transfer address. 
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Instruction Set of the I/O Processor 

I/O Instructions 


Bit 25 Table Indirect Mode 

When this bit is set, the 24-bit signed value in 
the DBG register is added to the value in the 
DSA register, used as an offset relative to the 
value in the Data Structure Base Address 
(DSA) registeroThe SCNTL3 value, SCSI ID, 
synchronous offset and synchronous period are 
loaded from this address. Prior to the start of 
an I/O, the DSA should be loaded with the 
base address of the I/O data structure^The 
address may be any address on a longword 
boundary. After a Table Indirect op code is 
fetched, the DSA is added to the 24-bit signed 
offset value from the op code to generate the 
address of the required data; both positive and 
negative offsets are allowed. A subsequent 
fetch from that address brings the data values 
into the chip. 

SCRIPTS can directly execute operating sys¬ 
tem I/O data structures, saving time at the 
beginning of an I/O operation. The I/O data 
structure can begin on any longword boundary 
and may cross system segment boundaries. 
There are two restrictions on the placement of 
data in system memory: 

1. The I/O data structure must lie within the 8 
MB above or below the base address. 

2. An I/O command structure must have all four 
bytes contiguous in system memory, as shown 
below. The offset/period bits are ordered as in 
the SXFER register. The configuration bits are 
ordered as in the SCNTL3 register. 


Config 

ID 

Offset/ 

period 

(00) 


This bit should only be used in conjunction 
with the Select, Reselect, Wait Select, and Wait 
Reselect instructions. Bits 25 and 26 may be 
set individually or in combination: 



Bit 25 

Bit 26 

Direct 

0 

0 

Table Indirect 

0 

1 

Relative 

1 

0 

Table Relative 

1 

1 


Direct 

Uses the device ID and physical address in the 
instruction. 


Command 

ID 

Not Used 

Not Used 

Absolute Alternate Address 


Table Indirect 

Uses the physical jump address, but fetches data 
using the table indirect method. 


Command 


Table Offset 


Absolute Alternate Address 


Relative 

Uses the device ID in the instruction, but treats 
the alternate address as a relative jump 


Command 

ID 

Not 

Not 



Used 

Used 


Alternate Jump Offset 
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Instruction Set of the I/O Processor 

I/O Instructions 


Table Relative 

Treats the alternate jump address as a relative 
jump and fetches the device ID, s 5 mchronous off¬ 
set, and s57nchronous period indirectly. Adds the 
value in bits 23-0 of the first four bytes of the 
SCRIPTS instruction to the data structure base 
address to form the fetch address. 


Command 

Table Offset 

Alternate Jump Offset j 


Bit 24 Select with ATN/ 

This bit specifies whether SATN/ will be 
asserted during the selection phase when the 
SYM53C875 is executing a Select instruction. 
When operating in initiator mode, set this bit 
for the Select instruction. If this bit is set on 
any other I/O instruction, an illegal instruction 
interrupt is generated. 

Bit 23-20 Reserved 

Bits 19-16 Encoded SCSI Destination ID 

This 4-bit field specifies the destination SCSI 
ID for an I/O instruction. 

Bits 15-llReserved 
Bit 10 Set/Clear Carry 

This bit is used in conjunction with a Set or 
Clear instruction to set or clear the Carry bit. 
Setting this bit with a Set instruction asserts 
the Carry bit in the ALU. Setting this bit with a 
Clear instruction deasserts the Carry bit in the 
ALU. 

Bits 8-7 Reserved 

Bit 9 Set/Clear Target Mode 

This bit is used in conjunction with a Set or 
Clear instruction to set or clear target mode. 
Setting this bit with a Set instruction config¬ 
ures the SYM53C875 as a target device (this 
sets bit 0 of the SCNTLO register). Setting this 
bit with a Clear instruction configures the 
SYM53C875 as an initiator device (this clears 
bit 0 of the SCNTLO register). 


Bit 6 Set/Clear SACK/ 

Bit 3 Set/Clear SATN/ 

These two bits are used in conjunction with a 
Set or Clear instruction to assert or deassert 
the corresponding SCSI control signal. Bit 6 
controls the SCSI SACK/ signal; bit 3 controls 
the SCSI SATN/ signal. 

Setting either of these bits will set or reset the 
corresponding bit in the SO CL register, 
depending on the instruction used. The Set 
instruction is used to assert SACK/ and/or 
SATN/ on the SCSI bus.The Clear instruction 
is used to deassert SACK/ and/or SATN/ on 
the SCSI bus. 

Since SACK/ and SATN/ are initiator signals, 
they will not be asserted on the SCSI bus 
unless the SYM53C875 is operating as an initi¬ 
ator or the SCSI Loopback Enable bit is set in 
the STEST2 register. 

The Set/Clear SCSI ACK/ATN instruction 
would be used after message phase Block Move 
operations to give the initiator the opportunity 
to assert attention before acknowledging the 
last message b 5 ^e. For example, if the initiator 
wishes to reject a message, an Assert SCSI 
ATN instruction would be issued before a 
Clear SCSI ACK instruction. 

Bits 2-0 Reserved 


Second Dword 

Bits 31-0 Start Address 

This 32-bit field contains the memory address 
to fetch the next instruction if the selection or 
reselection fails. 

If relative or table relative addressing is used, 
this value is a 24-bit signed offset relative to the 
current DSP register value. 
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Read/Write Instructions 


Read/Write Instructions 

The Read/Write instruction supports addition, 
subtraction, and comparison of two separate values 
within the chip. It performs the desired operation 
on the specified register and the SFBR register, 
then stores the result back to the specified register 
or the SFBR. 


First Dword 

Bits 31-30 Instruction Type - ReadAVrite 
Instruction 

The Read/Write instruction uses operator bits 
26 through 24 in conjunction with the op code 
bits to determine which instruction is currently 
selected. 



DSPS Register 


31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 6~4i ReadAVrite Instruction Register 
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Instruction Set of the I/O Processor 

Read/Write Instructions 


Bits 29-27 Op Code 

The combinations of these bits determine if the 
instruction is a Read/Write or an I/O instruc¬ 
tion. Op codes 000 through 100 are considered 
I/O instructions. 

Bits 26-24 Operator 

These bits are used in conjunction with the op 
code bits to determine which instruction is 
currently selected. Refer to table 6-1 for field 
definitions. 

Bit 23 Use dataS/SFBR 

When this bit is setj SFBR will be used instead 
of the dataS value during a Read-Modify-Write 
instruction (see Table 6-1).This allows the 
user to add two register values. 

Bits 22-16 Register Address - A(6-0) 

Register values may be changed from 
SCRIPTS in read-modify-write cycles or move 
to/ffom SFBR cycles. A(6-0) select an 8-bit 
source/destination register within the 
SYM53C875. 

Bits 15-8 Immediate Data 

This 8-bit value is used as a second operand in 
logical and arithmetic functions. 

Bits 7-0 Reserved 


Second Dword 

Bits 31-0 Destination Address 

This field contains the 32-bit destination 
address where the data is to be moved. 


Read-Modify-Write 

Cycles 

During these cycles the register is read^ the 
selected operation is performed, and the result is 
written back to the source register. 

The Add operation can be used to increment or 
decrement register values (or memory values if 
used in conjunction with a Memory-to-Register 
Move operation) for use as loop counters. 


Subtraction is not available when SFBR is used 
instead of data8 in the instruction syntax. To sub¬ 
tract one value from another when using SFBR, 
first XOR the value to subtract (subtrahend) with 
OxFF, and add 1 to the resulting value.This creates 
the 2^s compliment of the subtrahend. The two val¬ 
ues can then be added to obtain the difference. 


Move to/from 
SFBR Cycles 

All operations are read-modify-writes. However, 
two registers are involved, one of which is always 
the SFBR. The possible functions of this instruc¬ 
tion are: 

■ Write one byte (value contained within the 
SCRIPTS instruction) into any chip register. 

■ Move to/ffom the SFBR from/to any other 
register. 

■ Alter the value of a register with AND/OR/ 
ADD/XOR/SHIFT LEFT/SHIFT RIGHT 
operators. 

■ After moving values to the SFBR, the compare 
and jump, call, or similar instructions may be 
used to check the value. 

■ A Move-to-SFBR followed by a Move-ff om- 
SFBR can be used to perform a register to 
register move. 
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Read/Write Instructions 



Table 6-1 s 

Read/Write Instructions 


Operator 

Op Code 111 

Read Modify Write 

Op Code 110 

Move to SFBR 

Op Code 101 

Move from SFBR 

000 

Move data into register. 
Syntax: “Move dataS to 
RegA’’ 

Move data into SFBR regis¬ 
ter. Syntax: “Move dataS to 
SFBR” 

Move data into register. 
Syntax: “Move dataS to 

RegA” 

001* 

Shift register one bit to the 
left and place the result in 
the same register. Syntax: 
“Move RegA SHL RegA” 

Shift register one bit to the 
left and place the result in 
the SFBR register. Syntax: 
“Move RegA SHL SFBR” 

Shift the SFBR register one 
bit to the left and place the 
result in the register. Syntax: 
“Move SFBR SHL RegA” 

010 

OR data with register and 
place the result in the same 
register. Syntax: “Move 

RegA I dataS to RegA” 

OR data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA 1 dataS to SFBR” 

OR data with SFBR and 
place the result in the regis¬ 
ter, Syntax: “Move SFBR | 
dataS to RegA” 

on 

XOR data with register and 
place the result in the same 
register. Syntax: “Move 

RegA XOR dataS to RegA” 

XOR data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA XOR dataS to SFBR” 

XOR data with SFBR and 
place the result in the regis¬ 
ter. Syntax: “Move SFBR 
XOR dataS to RegA” 

100 

AND data with register and 
place the result in the same 
register. Syntax: “Move 

RegA & dataS to RegA” 

AND data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA & dataS to SFBR” 

AND data with SFBR and 
place the result in the regis¬ 
ter. Syntax: “Move SFBR & 
dataS to RegA” 

ion 

Shift register one bit to the 
right and place the result in 
the same register. Syntax: 
“Move RegA SHR RegA” 

Shift register one bit to the 
right and place the result in 
the SFBR register. Syntax: 
“Move RegA SHR SFBR” 

Shift the SFBR register one 
bit to the right and place the 
result in the register. Syntax: 
“Move SFBR SHR RegA” 

no 

Add data to register without 
carry and place the result in 
the same register. Syntax: 
“Move RegA + dataS to 
RegA” 

Add data to register without 
carry and place the result in 
the SFBR register. Syntax: 
“Move RegA + dataS to 
SFBR” 

Add data to SFBR without 
carry and place the result in 
the register. Syntax: “Move 
SFBR + dataS to RegA” 

111 

Add data to register with 
carry and place the result in 
the same register. Syntax: 
“Move RegA + dataS to 

RegA with carry” 

Add data to register with 
carry and place the result in 
the SFBR register. Syntax: 
“Move RegA -I- dataS to 

SFBR with carry” 

Add data to SFBR with 
carry and place the result in 
the register. Syntax: “Move 
SFBR + dataS to RegA with 
carry” 


Notes: 

1. Substitute the desired register name or address for ^^RegA^^in the syntax examples 

2. dataS indicates eight bits of data 

3. Use SFBR instead of dataS to add two register values. 

Data is shifted through the Carry bit and the Carry bit is shifted into the data byte 
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Transfer Control 
Instructions 


2. If the comparisons are false, the SYM53C87 5 
fetches the next instruction from the address 
pointed to by the DSP register, leaving the 
instruction pointer unchanged. 


First Dword 

Bits 31-30 Instruction Type - Transfer Control 
Instruction 

Bits 29-27 Op Code 

This 3-bit field specifies the type of transfer 
control instruction to be executed. All transfer 
control instructions can be conditional. They 
can be dependent on a true/false comparison 
of the ALU Carry bit or a comparison of the 
SCSI information transfer phase with the 
Phase field, and/or a comparison of the First 
B5^e Received with the Data Compare field. 
Each instruction can operate in initiator or tar¬ 
get mode. 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Jump 

0 

0 

1 

Call 

0 

1 

0 

Return 

0 

1 

1 

Interrupt 

1 

X 

X 

Reserved 


CaU Instruction 

1. The SYM53C875 can do a true/false 
comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare, and True/False bit 
fields. If the comparisons are true, the 
SYM53C875 loads the DSP register with the 
contents of the DSPS register and that address 
value becomes the address of the next 
instruction. 

When the SYM53C875 executes a Call 
instruction, the instruction pointer contained 
in the DSP register is stored in the TEMP reg¬ 
ister. Since the TEAIP register is not a stack 
and can only hold one longword, nested call 
instructions are not allowed. 

2. If the comparisons are false, the SYM53C875 
fetches the next instruction from the address 
pointed to by the DSP register and the 
instruction pointer is not modified. 


Jump Instruction 

1. The SYM53C875 can do a true/false 

comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare and True/False bit 
fields. If the comparisons are true, the 
SYM53C875 loads the DSP register with the 
contents of the DSPS register. The DSP 
register now contains the address of the next 
instruction. 
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Instruction Set of the I/O Processor 

Transfer Control Instructions 


DCMD Register 


DBC Register ■ 


31 30 29 28 27 26 25 24123 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


Mask for compare 


Wait for Valid Phase 
■— Compare Phase 
Compare Data 

'— Jump if: True=1, False=0 
'— Interrupt on the Fly 
Carry Test 
'— 0 (Reserved) 

'— Relative addressing mode 
•—I/O 
■—C/D 
•—MSG 
•— Op Code bit 0 
Op Code bit 1 
Op Code bit 2 
0 - Instruction Type - Transfer Control 
1- Instruction Type - Transfer Control 




Data to be compared 
with the SCSI Rrst 
Byte Received 


DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


Figure 6-5$ Transfer Control Instruction 
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Instruction Set of the I/O Processor 

Transfer Control Instructions 


Return Instruction 

L The SYM53C875 can do a true/false 

comparison of the ALU carry bitj or compare 
the phase and/or data as defined by the Phase 
Compare^ Data Compare, and True/False bit 
fields. If the comparisons are true, then the 
SYM53C875 loads the DSP register with the 
contents of the DSPS register. That address 
value becomes the address of the next 
instruction. 

When a Return instruction is executed, the 
value stored in the TEMP register is returned 
to the DSP register,The SYM53C875 does 
not check to see whether the Call instruction 
has already been executed. It will not generate 
an interrupt if a Return instruction is executed 
without previously executing a Call instruc¬ 
tion, 

2, If the comparisons are false, then the 

SYM53C875 fetches the next instruction from 
the address pointed to by the DSP register and 
the instruction pointer will not be modified. 

Interrupt Instructions 

Interrupt 

a) The SYM53C875 can do a true/false 
comparison of the ALU carry bit, or 
compare the phase and/or data as defined 
by the Phase Compare, Data Compare, 
and True/False bit fields. If the 
comparisons are true, then the 
SYM53C875 generates an interrupt by 
asserting the IRQ/ signal, 

b) The 32-bit address field stored in the 
DSPS register (not DNAD as in 53C700) 
can contain a unique interrupt service 
vector. When servicing the interrupt, this 
unique status code allows the ISR to 
quickly identify the point at which the 
interrupt occurred. 

c) The SYM53C875 halts and the DSP 
register must be written to start any fiirther 
operation. 


Interrupt on-the-Fly 

a) The SYM53C875 can do a true/false 
comparison of the ALU carry bit or 
compare the phase and/or data as defined 
by the Phase Compare, Data Compare, 
and True/False bit fields. If the 
comparisons are true, and the Interrupt on 
the Fly bit is set (bit 20), the SYM53C875 
will assert the Interrupt on the Fly bit 
(ISTAT bit 2). 

Bits 26-24 SCSI Phase 

This 3-bit field corresponds to the three SCSI 
bus phase signals which are compared with the 
phase lines latched when SREQ/ is asserted. 
Comparisons can be performed to determine 
the SCSI phase actually being driven on the 
SCSI bus. The following table describes the 
possible combinations and their correspond¬ 
ing SCSI phase. These bits are only valid when 
the SYM53C875 is operating in initiator 
mode; when the SYM53C875 is operating in 
the target mode, these bits should be cleared. 


MSG 

C/D 

I/O 

SCSI Phas6 

0 

0 

0 

Data out 

0 

0 

1 

Data in 

0 

1 

0 

Command 

0 

1 

1 

Status 

1 

0 

0 

Reserved out 

1 

0 

1 

Reserved in 

1 

1 

0 

Message out 

1 

1 

1 

Message in 


Bit 23 Relative Addressing Mode 

When this bit is set, the 24-bit signed value in 
the DSPS register is used as a relative offset 
firom the current DSP address (which is point¬ 
ing to the next instruction, not the one cur¬ 
rently executing). Relative mode does not 
apply to Return and Interrupt SCRIPTS. 
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Instruction Set of the I/O Processor 

Transfer Control Instructions 


Jump/Call an Absolute Address 

Start execution at the new absolute address. 


Command 

Condition Codes 

Absolute Alternate Address 


Jump/Call a Relative Address 

Start execution at the current address plus (or 
minus) the relative offset. 


Command 

Condition Codes 

Don’t Care 

Alternate Jump Offset 


The SCRIPTS program counter is a 32-bit 
value pointing to the SCRIPT currently being 
executed by the SYM53C875.The next 
address is formed by adding the 32-bit pro¬ 
gram counter to the 24-bit signed value of the 
last 24 bits of the Jump or Call instruction. 
Because it is signed (twos compliment), the 
jump can be forward or backward. 

A relative transfer can be to any address within 
a 16-MB segment. The program counter is 
combined with the 24-bit signed offset (using 
addition or subtraction) to form the new exe¬ 
cution address. 

SCRIPTS programs may contain a mixture of 
direct jumps and relative jumps to provide 
maximum versatility when writing SCRIPTS. 
For example, major sections of code can be 
accessed with far calls using the 32-bit physical 
address, then local labels can be called using 
relative transfers. If a SCRIPT is written using 
only relative transfers it would not require any 
run time alteration of physical addresses, and 
could be stored in and executed from a 
PROM. 

Bit 21 Carry Test 

When this bit is set, decisions based on the 
ALU carry bit can be made. True/False com¬ 
parisons are legal, but Data Compare and 
Phase Compare are illegal. 


Bit 20 Interrupt on the Fly 

When this bit is set, the interrupt instruction 
will not halt the SCRIPTS processor. Once the 
interrupt occurs, the Interrupt on the Fly bit 
(ISTAT bit 2) will be asserted. 

Bit 19 Jump IfTrue/False 

This bit determines whether the SYM53C875 
should branch when a comparison is true or 
when a comparison is false. This bit applies to 
phase compares, data compares, and carry 
tests. If both the Phase Compare and Data 
Compare bits are aet, then both compares 
must be true to branch on a true condition. 
Both compares must be false to branch on a 
false condition. 


Bit 19 

Result of 
Compare 

Action 

0 

False 

Jump Taken 

0 

True 

No Jump 

1 

False 

No Jump 

1 

True 

Jump Taken 


Bit 18 Compare Data 

When this bit is set, the first byte received from 
the SCSI data bus (contained in SFBR regis¬ 
ter) is compared with the Data to be Com¬ 
pared Field in the Transfer Control instruction. 
The Wait for Valid Phase bit controls when this 
compare will occur. The Jump if True/False bit 
determines the condition (true or false) to 
branch on. 

Bit 17 Compare Phase 

When the SYM53C875 is in initiator mode, 
this bit controls phase compare operations. 
When this bit is set, the SCSI phase signals 
(latched by SREQ/) are compared to the Phase 
Field in the Transfer Control instruction; if 
they match, the comparison is true. The Wait 
for Valid Phase bit controls when the compare 
will occur. When the SYM53C875 is operating 
in target mode this bit, when set, tests for an 
active SCSI SATN/ signal. 
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Instruction Set of the I/O Processor 

Memory Move Instructions 


Bit 16 Wait For Valid Phase 

If the Wait for Valid Phase bit is set, the 
SYM53C875 waits for a previously unserviced 
phase before comparing the SCSI phase and 
data. 

If the Wait for Valid Phase bit is clear^ the 
SYM53C875 compares the SCSI phase and 
data immediately. 

Bits 15-8 Data Compare Mask 

The Data Compare Mask allows a SCRIPT to 
test certain bits within a data byte. During the 
data compare^ any mask bits that are set cause 
the corresponding bit in the SFBR data b 5 ^e to 
be ignored. For instance, a mask of 01111111b 
and data compare value of IXXXXXXXb 
allows the SCRIPTS processor to determine 
whether or not the high order bit is set while 
ignoring the remaining bits. 

Bits 7-0 Data Compare Value 

This 8-bit field is the data to be compared 
against the SCSI First Byte Received (SFBR) 
register. These bits are used in conjunction 
with the Data Compare Mask Field to test for 
a particular data value. 


Second Dword 

Bits 31-0 Jump Address 

This 32-bit field contains the address of the 
next instruction to fetch when a jump is taken. 
Once the SYM53C875 has fetched the instruc¬ 
tion firom the address pointed to by these 32 
bits, this address is incremented by 4, loaded 
into the DSP register and becomes the current 
instruction pointer. 


Memory Move Instructions 

For Memory Move instructions, bits 5 and 4 
(SIOM and DIOM) in the DMODE register 
determine whether the source or destination 
addresses reside in memory or I/O space. By set¬ 
ting these bits appropriately, data may be moved 
within memory space, within I/O space, or 
between the two address spaces. 

The Memory Move instruction is used to copy the 
specified number of bytes fi:om the source address 
to the destination address. 

Allowing the SYM53C875 to perform memory 
moves firees the system processor for other tasks 
and moves data at higher speeds than available 
from current DMA controllers. Up to 16 MB may 
be transferred with one instruction.There are two 
restrictions: 

1. Both the source and destination addresses 
must start with the same address alignment 
(A(l-O) must be the same). If source and 
destination are not aligned, then an illegal 
instruction interrupt will occur. For the PCI 
Cache Line Size register setting to take effect, 
the source and destination must be the same 
distance firom a cache line boundary. 

2. Indirect addresses are not allowed. A burst of 
data is fetched from the source address, put 
into the DMA FIFO and then written out to 
the destination address. The move continues 
until the byte count decrements to zero, then 
another SCRIPT is fetched from system 
memory. 

The DSPS and DSA registers are additional hold¬ 
ing registers used during the Memory Move; how¬ 
ever, the contents of the DSA register are 
preserved. 

Bits 3l-39Instraction Type—Memory Move 
Bits 28-25 Reserved 

These bits are reserved and must be zero. If 
any of these bits is set, an illegal instruction 
interrupt will occur. 


6-20 


SYM53C875 Data Manual 



Instruction Set of the I/O Processor 

Memory Move Instructions 


Bit 24 No Flush 

Note: this bit has no efifect unless the Pre-fetch 
Enable bit in the DCNTL register is seto 
For information on SCRIPTS instruction 
prefetching, see Chapter 2. 

When this bit is set, the SYM53C875 performs a 
Memory Move without flushing the prefetch unit. 
When this bit is clear, the Memory Move instruc¬ 
tion automatically flushes the prefetch unit. The 
No Flush option should be used if the source and 
destination are not within four instructions of the 
current Memory Move instruction. 

Bits 23-0 Transfer Count 

The number of bytes to be transferred is stored 
in the lower 24 bits of the first instruction 
word. 


Second Dword 

Bits 31-0, DSPS Register 

These bits contain the source address of the 
Memory Move. 


Third Dword 

Bits 31-0, TEMP Register 

These bits contain the destination address for 
the Memory Move. 


Read/Write System 
Memory from a Script 

By using the Memory Move instruction, single or 
multiple register values may be transferred to or 
from system memory. 

Because the SYM53C875 will respond to 
addresses as defined in the Base FO or Base Mem¬ 
ory registers, it could be accessed during a Mem¬ 
ory Move operation if the source or destination 
address decodes to within the chip^s register space. 
If this occurs, the register indicated by the lower 
seven bits of the address is taken to be the data 
source or destination. In this way, register values 
can be saved to system memory and later restored, 
and SCRIPTS can make decisions based on data 
values in system memory. 

The SFBR is not writable via the CPU, and there¬ 
fore not by a Memory Move. However, it can be 
loaded via SCRIPTS Read/Write operations. To 
load the SFBR with a byte stored in system mem¬ 
ory, the byte must first be moved to an intermedi¬ 
ate SYM53C875 register (for example, a 
SCRATCH register), and then to the SFBR 

The same address alignment restrictions apply to 
register access operations as to normal memory-to- 
memory transfers. 
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Instruction Set of the I/O Processor 

Memory Move Instructions 



DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



TEMP Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 6-6: Memory Move Instructions 
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Instruction Set of the I/O Processor 

Load and Store Instructions 


Load and Store 
Instructions 

The Load and Store instruction provides a more 
efficient way to move data fi:om/to memory to/firom 
an internal register in the chip without using the 
normal memory move instruction. 

The load and store instructions are represented by 
two-dword op codes. The first dword contains the 
DCMD and DBG register values.The second 
dword contains the DSPS value. This is either the 
actual memory location of where to load or store, 
or the offset firom the DSA, depending on the 
value of Bit 28 (DSA Relative). 

A maximum of 4 bytes may be moved with these 
instructions. The register address and memory 
address must have the same byte alignment, and 
the count set such that it does not cross dword 
boundaries. The destination memory address in 
the Store instruction and the source memory 
address of the Load instruction may not map back 
to the operating register set of the chip. This 
excludes the SCRIPTS RAM and ROM memory 
spaces. If it does, a PCI read/write cycle will occur 
(the data does not actually transfer to/firom the 
chip), and the chip will issue an interrupt (Illegal 
Instruction Detected) immediately following. 


Bits A1, AO 

Number of bytes allowed to load/store 

00 

One^ two, three or four 

01 

One, two, or three 

10 

One or two 

11 

One 


The SIOM and DIOM bits in the DMODE regis¬ 
ter determine whether the destination or source 
address of the instruction is in Memory space or 
I/O space, as illustrated in the following table. The 
Load/Store utilizes the PCI commands for I/O 
READ and I/O WRITE to access the I/O space. 


First Dword 

Bit 31-29, Instruction Type 

These bits should be 111, indicating the Load and 
Store instruction. 

Bit 28, DSA Relative 

When this bit is clear, the value in the DSPS is 
the actual 32-bit memory address to perform 
the load/store to/from. When this bit is set, the 
chip determines the memory address to per¬ 
form the load/store to/from by adding the 24- 
bit signed offset value in the DSPS to the DSA. 

Bits 27-26, Reserved 

Bit 25, No Flush (Store instruction only) 

Note: this bit has no effect unless the Pre-fetch 
Enable bit in the DCNTL register is set. 
For information on SCRIPTS instruction 
prefetching, see Chapter 2. 

When this bit is set, the SYM53C875 performs 
a Store without flushing the prefetch unit. 
When this bit is clear, the Store instruction 
automatically flushes the prefetch unit. No 
Flush should be used if the source and destina¬ 
tion are not within four instructions of the cur¬ 
rent Store instruction. This bit is has no effect 
on the Load instruction. 

Bit 24, Load/Store 

When this bit is set, the instruction is a Load. 
When cleared, it is a Store. 

Bit 23, Reserved 

Bits 22-16, Register Address 

A6-A0 select the register to load/store to/fi:om 
within the SYM53C875. 

Note: it is not possible to Load the SFBR 

register, although it is possible to store the 
SFBR contents to another location. 

Bits 15-3, Reserved 
Bits 2-0, Byte Count 

This value is the number of bj^tes to load/store. 


Bit 

Source 

Destination 

SIOM (Load) 

memory 

register 

DIOM (Store) 

register 

memory 


SYM53C875 Data Manual 


6-23 




















Electrical Characteristics 

DC Characteristics 


Chapter 7 

Electrical Characteristics 


DC Characteristics 

Table 7-1: Absolute Maximum Stress Ratings 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Tstg 

Storage temperature 

-55 

150 

°C 

- 

Vdd 

Supply voltage 

-0.5 

7.0 

V 

- 

ViN 

Input Voltage 

Vss-0.5 

^dD 0-5 

V 

- 

IIP* 

Latch-up current 

± 150 

- 

mA 

- 

ESD** 

Electrostatic discharge 

- 

2K 

V 

MIL-STD 883C, 






Method 3015.7 


Stresses beyond those listed above may cause permanent damage to the device. These are stress ratings only; functional operation of 
the device at these or any other conditions beyond those indicated in the Operating Conditions section of the manual is not implied. 
^-2V<Vpi^<8V 

SCSI pins only 


Table 7-2: Operating Conditions 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vdd 

Supply voltage 

4.75 

5.25 

V 

- 

Idd 

Supply current (dynamic) 

- 

130 

mA 

- 


Supply current (static) 

- 

1 

mA 

- 

Ta 

Operating free air 

0 

70 

°C 

- 

0JA 

Thermal resistance (junc¬ 
tion to ambient air) 

- 

67 

°c/w 

- 


Conditions that exceed the operating limits may cause the device to function incorrectly 
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Electrical Characteristics 

DC Characteristics 


Table 7-3; SCSI S^als - SD(15-0)/, SDP(l-O)/, SREQ/ SACK/ 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

^DD 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

VoH* 

Output high voltage 

2.5 

3.5 

V 

2.5 mA 

VoL 

Output low voltage 

Vss 

0.5 

V 

48 mA 

loz 

Tristate leakage 

-10 

10 

ma 

- 

"^TolerANT active negation enabled 






Table 7-4: SCSI Signals - SMSG, SI_0/, SC_D/, SATN/, SBSYi 

, SSEL/, 

SRST/ 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd + 0.5 

V 

- 

ViL 

Input low voltage 

Vss - 0.5 

0.8 

V 

- 

Vql 

Output low voltage 

Vss 

0.5 

V 

48 mA 

Iqz 

Tristate leakage 

-10 

10 

MA 

- 


(SRST/ only) 

-500 

-50 




Table 7-5: Input Signals - 

CLK, SCLK, 

GNT/, IDSEL, RST/, TESTIN, 

DIFFSENS, BIG_LIT/ 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 0.5 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

IlN 

Input leakage 

-10 

10 

HA 

- 


Note; CLK, SCLK, and BIG_LIT/,have 100\iA pull-ups, and GNTl and IDSEL have 25 fiA pull-ups, that are enabled when 
TESTIN is low. TESTIN has a lOOpA puH-up that is always enabled. 
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Electrical Characteristics 

DC Characteristics 


Table 7-6: Capacitance 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 


Input capacitance of 
input pads 

- 

7 

pF 

- 

Cjo 

Input capacitance of I/O 
pads 

- 

10 

pF 

- 


Table 7- 

■7: Output Signal 

- MAC/_TESTOUT, REQ/ 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vqh 

Output high voltage 

2.4 

Vdd 

V 

-16 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

16 mA 

Iqz 

Tristate leakage 

-10 

10 

MA 

- 

Note: REQ! has a 100 \iA pull-up that is enabled when TESTIN is 

low 



Table 7-8: Output Signals - IRQ/, SDIR(15-0), SDIRPO, SDIRPl, BSYDIR, 

2VIAS/(l-0), MCE/, MOE/, MWE/ 

SELDIR, RSTDIR,TGS, IGS, 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vqh 

Output high voltage 

2.4 

Vdd 

V 

-4 mA* 

VoL 

Output low voltage 

Vss 

0.4 

V 

4 mA* 

^OZ 

Tristate leakage 

-10 

10 

MA 

- 

Note: IRQ!i MAS!(1-0)^ MCEl^ MOEI, and MWE! have a 100\yA pull-up that is enabled when TESTIN is 
enabled with a register bit as an open drain output with an internal lOOjiA pull-up. 

low. IRQ! can be 

^for IRQ/, Test Conditions are ± 8mA 







Table 7-9: Output Signal - SERR/ 



Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vql 

Output low voltage 

Vss 

0.4 

V 

16 mA 

Iqz 

Tristate leakage 

-10 

10 

ma 



SYM53C875 Data Manual 


7-3 














Electrical Characteristics 

DC Characteristics 


Table 7-10: 

Bidirectional Signals - AD(31-0), C_BE:/(3-0), FRAME/, IRDY/,TRDY/, DEVSEL/, 

BYTEPAR3-0 (53C875N only) 

STOP/, PERR/, PAR, 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd + 0.5 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

Vqh 

Output high voltage 

2.4 

Vdd 

V 

16 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

16 mA 

Iqz 

Tristate leakage 

-10 

10 

ma 

- 

Note:AU the signals in this table have 25 \xA pull-ups that are enabled when TESTIN is low 



Table 7-11: Bidirectional Signals 

- GPIOO_FETCH/ 

, GPI01_MASTER/, 

GPI02_MAS2/, 

, GPI03, GPI04 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 0-5 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

VoH 

Output high voltage 

2.4 

Vdd 

V 

-16 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

16 mA 

o 

N 

Tristate leakage 

-10 

10 

ma 

- 


Note; All the signals in this table hceve 100\iA puM-ups that are enabled when TESTIN is low 
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DC Characteristics 


Table 7-12: Bidirectional Signals - MAD(7-0) 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 0.5 

V 

- 

ViH 

Input high voltage - 
external memory pull- 
downs 

3.85 

^DD 

V 

~ 

ViL 

Input low voltage 

Vss - 0.5 

0,8 

V 

- 

ViL 

Input low voltage - exter¬ 
nal memory pull-downs 

Vss - 0.5 

1.35 

V 

” 

Vqh 

Output high voltage 

2.4 

Vdd 

V 

-4 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

4mA 

Iqz 

Tristate leakage 

-10 

10 

MA 

- 

Note: All the signals in this table have 100\xA pull-ups that are enabled when TESTIN is low 




Table 7-13; Input Signals —TDI,TMS, TCK (53C875J,53C875JB, 53C875N only) 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

3.85 

Vdd ■*" 

V 


ViL 

Input low voltage 

Vss - 0.5 

1.35 

V 

- 

^IN 

Input leakage 

-800 

-200 

|JA 



Table 7-14: Output Signal — 

TDO (53C875, 53C875JB, 53C875N only) 


Symbol 

Parameters 

Min 

Max 

Units 

Test Conditions 

Vqh 

Output high voltage 

Vdd • 0.5 

Vdd 

V 

-4 mA 

VoL 

Output low voltage 

Vss 

0.5 

V 

4 mA 

Iqz 

Tristate leakage 

-10 

10 

HA 

- 
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TolerANT Technology Electrical Characteristics 

Table 7-15: TolerANT Technology Electrical Characteristics 

Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

Voh' 

Output high voltage 

2.5 

3.5 

V 

Iqh “ 2.5 mA 

Vql 

Output low voltage 

0,1 

0.5 

V 

loL = 48 mA 

ViH 

Input high voltage 

2.0 

7,0 

V 


ViL 

Input low voltage 

-0.5 

0,8 

V 

Referenced to 

ViK 

Input clamp voltage 

-0.66 

-0.77 

V 

Vdd = 4.75; 

Ij = -20 mA 

Vth 

Threshold^ high to low 

1.1 

1.3 

V 

- 

Vtl 

Threshold^ low to high 

1.5 

1.7 

V 

- 

VtH- 

Vtl 

Hysteresis 

200 

400 

mV 

- 

T ^ 

Output high current 

2.5 

24 

mA 

^OH = 2.5 V 

Iql 

Output low current 

100 

200 

mA 

Vol=0.5V 

T 1 
^OSH 

Short-circuit output 
high current 

- 

625 

mA 

Output driving low, 
pin shorted to 
supply^ 

Iqsl 

Short-circuit output low 
current 


95 

mA 

Output driving 
high, pin shorted to 
Vss supply 

Ilh 

Input high leakage 

- 

10 

ma 

-0.5 <Vdd < 5,25 
VpiN = 2.7 V 

III 

Input low leakage 

- 

-10 

MA 

-0.5 <Vdd< 5.25 
VpiN = 0.5 V 

R] 

Input resistance 

20 

- 

MD. 

SCSI pins^ 

Cp 

Capacitance per pin 

- 

10 

pF 

PQFP 

tR* 

Rise timej 10% to 90% 

9,7 

18.5 

ns 

Figure 7-1 

% 

Fall time^ 90% to 10% 

5.2 

14.7 

ns 

Figure 7-1 


Note: These values are guaranteed by periodic characterization; they are not 100% tested on every device. 
^ Active negation outputs only: Data, Parity, SREQl, SACK/ 

^Single pin only; irreversible damage may occur if sustained for one second 
^SCSI RESET pin has 10 kD. pull-up resistor 
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Table 7-15: TolerANT Technology Electrical Characteristics (Continued) 


Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

< 

X 

(-t 

Slew rate^ low to high 

0.15 

0.49 

V/ns 

Figure 7-1 

dVL/dt 

Slew rate^ high to low 

0.19 

0.67 

V/ns 

Figure 7-1 

ESD 

Electrostatic discharge 

2 

- 

KV 

MIL-STD-883C; 

3015-7 


Latch-up 

100 

- 

mA 

- 


Filter delay 

20 

30 

ns 

Figure 7-2 


Extended filter delay 

40 

60 

ns 

Figure 7-2 


Note: These values are guaranteed by periodic characterization; they are not 100% tested on every device. 
^ Active negation outputs only: Data, Parity, SREQf, SACK! 

^Single pin only; irreversible damage may occur if sustained for one second 
^SCSI RESET pin has 10 kD. pull-up resistor 


47 Q. 



Figure 7-1: Rise and Fall Time Test Conditions 


REQ/or ACK/ Input 


is the input filtering period, 



Figure 7-2: SCSI Input Filtering 
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OUTPUT SINK CURRENT (milliAmperes) 


Electrical Characteristics 

TolerANT Technology Electrical Characteristics 



Input Voltage (Volts) 

Figure 7-3; Hysteresis of SCSI Receiver 
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03 

+20 
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1.4 V 
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O -20 _ 

-0.7 V 
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l-Z 

1— 

ID 

o. 

z 

-40 _ 




OUTPUT 

ACTIVE 




1 






-4 0 4 8 12 16 

INPUT VOLTAGE (Volts) 


Figure 7-4; Input Current as a Function of Input Voltage 




OUTPUT VOLTAGE (Volts) OUTPUT VOLTAGE (Volts) 

Figure 7-5; Output Current as a Function of Output Voltage 
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AC Characteristics 


AC Characteristics 

The AC characteristics described in this section apply over the entire range of operating conditions (refer 
to the DC Characteristics section). Chip timings are based on simulation at worst case voltage, tempera¬ 
ture, and processing. Timings were developed with a load capacitance of 50 pF. 

Figure 7-6: Clock Timing 

Symbol 

Parameter 

Min 

Max 

Units 

h 

Bus clock cycle time 

30 

DC 

ns 


SCSI clock cycle time (SCLK)* 12.5 

60 

ns 

^2 

CLK low time"*^* 

12 

- 

ns 


SCLK low time** 

5 

- 

ns 

^3 

CLK high time** 

12 

- 

ns 


SCLK high time** 

5 

- 

ns 


CLK slew rate 

1 

- 

V/ns 


SCLK slew rate 

1 

- 

V/ns 


* This parameter must be met to insure SCSI timings are vntMn specification 
**Duty cycle not to exceed 60/40 


CLK/SCLK 



-ti- 

1 

\ _ / 


^2 
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Figure 7-7: Reset Input 


Symboi 

Parameter 

Min 

Max 

Units 

ti 

Reset pulse width 

10 

-■ 

’^CLK 

t2 

Reset deasserted setup to CLK high 

0 

- 

ns 

^3 

MAD setup time to CLK high (for configuring the 
MAD bus only) 

20 

- 

ns 

U 

MAD hold time from CLK high (for configuring the 
MAD bus only) 

20 

- 

ns 



Figure 7-8: Interrupt Output 


Symboi 

Parameter 

Min 

Max 

Units 

tl 

CLK high to IRQ/low 

20 

- 

ns 

^2 

CLK high to IRQ/high 

40 

- 

ns 


IRQ/ deassertion time 

3 

- 

CLKs 
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PCI and External Memory Interface Timing Diagrams 


PCI and External Memory Interface Timing Diagrams 

Figure 7-9 through Figure 7-30 represent signal activity when the SYM53C875 accesses the PCI bus.The 
timings for the PCI and external memory buses are listed on page 7-34.This section includes timing dia¬ 
grams for access to three groups of external memory configurations. The first group applies to systems 
with memory size of 128 KB and above; one b54:e read or write cycle, and fast or normal ROMs. The sec¬ 
ond group applies to systems with memory size of 128 KB and above, one-b37te read or write cycles, and 
slow ROMs. The third group applies to systems with memory size of 64 KB or less, one-b34:e read or write 
cycles, and normal or fast ROM. 

Note: multiple byte accesses to the external memory bus increase the read or write cycle by 11 clocks for 
each additional byte. 


Timing diagrams included in this section 
Target Cycles 

■ PCI configuration register read 

■ PCI configuration register write 

■ Operating Register/S CRIPTS RAM read 

■ Operating Register/S CRIPTS RAM write 

■ External Memory Read 

■ External Memory Write 

Initiator Cycles 

■ Op code fetch, non-burst 

■ Burst op code fetch 

■ Back-to-back read 

■ Back-to-back write 

■ Burst read 

■ Burst write 

External Memory Cycles 

■ Read cycle, normal/fast memory (> 64K), single-byte access 

■ Write cycle, normal/fast memory ^ 64IQ, single-byte access 

■ Read cycle, normal/fast memory (> 64K), multiple-bj^e access 

■ Write cycle, normal/fast memory (> 64K), multiple-byte access 

■ Read cycle, slow memory (> 64 K) 

■ Write cycle, slow memory (> 64 K) 

■ Read cycle, Normal/Fast Memory (>64 K) 

■ Write cycle, Normal/Fast Memory (>64 K) 

■ Read Cycle, Slow Memory (< 64 K) 

■ Write Cycle, Slow Memory (< 64K) 
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Figure 7-9: PCI Configuration Register Read 
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Figure 7-10: PCI Configuration Register Write 
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CLK 

(Driven by System) 


FRAME/ 
(Driven by Master) 


AD 

(Driven by Master-Addr; 
53C875-Data) 

C_BE/ 

(Driven by Master) 
PAR 

(Driven by Master-Addr; 
53C875-Data) 

IRDY/ 

(Driven by Master) 


TRDY 

(Driven by 53C875) 

STOP/ 

(Driven by 53C875) 

DEVSELY 
(Driven by 53C875) 
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Figure 7-12: Operating Register/SCRIPTS RAM write 
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1 2 3 4 5 6 7 8 9 10 11 
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CLK 

(Driven by System) 

FRAME/ 
(Driven by Master) 


AD 

(Driven by Master-Addr; 
53C875-Data) 

C_BE/ 

(Driven by Master) 
PAR 
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53C875-Data) 

IRDY/ 
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TRDY 
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(Driven by 53C875) 
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(Driven by 53C875) 
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(Driven by 53C875) 
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(Driven by 53C875) 
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CLK_ 
(Driven by System) 


GPIOOJETCH/ 
(Driven by 53C875)* 


GPI01 .MASTER/ 
(Driven by 53C875)* 

REQ/ 

(Driven by 53C875) 
GNT/ 

(Driven by Arbiter) 


FRAME/ 
(Driven by 53C875) 


AD/ 
(Driven by 
53C875-Addr; 
Target-Data) 


C.BE/ I 
(Driven by 53C875) 

PAR/. 
(Driven by 
53C875-Addr: 
Target-Data) 


IRDY/‘ 
(Driven by 53C875) 

TRDY/ ■ 

(Driven by Target) 

STOP/ 
(Driven by Target) 

DEVSEL/ ■ 
(Driven by Target) 



Figure 7-15: Op Code Fetch, non-burst 
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CLK 

(Driven by System) 
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(Driven by Target) 



Figure 7-17: Back to Bac k Read 
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Figure 7-21: Read Cycle, Normal/Fast Memory (>64 KB), single-byte access 
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Figure 7-22: Write Cycle, Normal/Fast Memory (>64 KB), single-byte access 
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Figure 7-23: Read Cycle, Normal/Fast Memory ^ 64 KB ), multiple-byte access 
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Figure 7-24: Write Cycle, Normal/Fast Memory (> 64 KB), multiple-byte access 
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Figure 7-25; Read Cycle, Slow Memory (>64 KB) 
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Figure 7-26: Write Cycle, Slow Memory (>64 KB) 
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Figure 7-27: Read Cycle, Normal/Fast Memory (< 64K) 
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Figure 7-28: Write Cycle, Normal/Fast Memory (< 64 K) 
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Figure 7-29: Read Cycle, Slow Memory (< 64K) 
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Figure 7-30: Write Cycle, Slow Memory (<64K) 
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PCI and External Memory Interface Timings 

Table 7-16: SY2V153C875 PCI and External Memory Interface Timings 

Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Shared signal input setup time 

7 

- 

ns 

h 

Shared signal input hold time 

0 

- 

ns 

% 

CLK to shared signal output valid 

- 

11 

ns 

^4 

Side signal input setup time 

10 

- 

ns 

% 

Side signal input hold time 

0 

- 

ns 

% 

CLK to side signal output valid 

- 

12 

ns 

^7 

CLK high to FETCH/ low 

- 

20 

ns 

% 

CLK high to FETCH/ high 

- 

20 

ns 

t9 

CLK high to MASTER/ low 

- 

20 

ns 

^10 

CLK high to MASTER/ high 

- 

20 

ns 

til 

Address setup to MAS/ high 

25 

- 

ns 

^12 

Address hold from MAS/ high 

15 

- 

ns 

h3 

MAS/ pulse width 

25 

- 

ns 

tl4f 

MCE/ low to data clocked in (fast memory) 

160 

- 

ns 

tl4s 

MCE/ low to data clocked in (slow memory) 

220 

- 

ns 

tl5f 

Address valid to data clocked in (fast memory) 

205 

- 

ns 

tl5s 

Address valid to data clocked in (slow memory) 

265 

- 

ns 

tl6f 

MOE/ low to data clocked in (fast memory) 

100 

- 

ns 

tl6s 

MOE/ low to data clocked in (slow memory) 

160 

- • 

ns 

tl7 

Data hold from address^ MOE/, MCE/ change 

0 

- 

ns 

tl8 

Next address out from MOE/, MCE/ high 

50 

- 

ns 

tl9 

Data setup to CLK high 

5 

- 

ns 

t20 

Data setup to MWE/ low 

30 

- 

ns 

t21 

Data hold from MWE/ high 

20 

- 

ns 

t22f 

MWE/ pulse width (fast memory) 

100 

- 

ns 

t22s 

MWE/ pulse width (slow memory) 

160 

- 

ns 
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Table 7-16: SYMS3C875 PCI and External Memory Interface Timings (Continued) 


Symbol 

Parameter 

Min 

Max 

Unit 

t23 

Address setup to MWE/ low 

75 

- 

ns 

’^24f 

MCE/ low to MWE/ high (fast memory) 

120 

- 

ns 

1^248 

MCE/ low to MWE/ high (slow memory) 

180 

- 

ns 

^25 

MCE/ low to MWE/ low 

25 

- 

ns 

*^26 

MWE/ high to MCE/ high 

25 


ns 
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SCSI Timings 

Figure 7-31: Initiator Asynchronous Send 


Symboi 

Parameter 

Min 

Max 

Units 


SACK/ asserted from SREQ/ asserted 

5 

- 

ns 

t2 

SACK/ deasserted from SREQ/ deasserted 

5 

- 

ns 

% 

Data setup to SACK/ asserted 

55 

- 

ns 


Data hold from SREQ/ deasserted 

20 

- 

ns 



Figure 7-32: Initiator Asynchronous Receive 


Symboi 

Parameter 

Min 

Max 

Units 


SACK/ asserted from SREQ/ asserted 

5 

- 

ns 

^2 

SACK/ deasserted from SREQ/ deasserted 

5 

- 

ns 

% 

Data setup to SREQ/ asserted 

0 

- 

ns 

U 

Data hold from SACK/ asserted 

0 

- 

ns 
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Figure 7-33: Target Asynchronous Send 


Symbol 

Parameter 

Min 

Max 

Units 


SREQ/ deasserted from SACK/ asserted 

5 

- 

ns 

^2 

SREQ/ asserted from SACK/ deasserted 

5 

- 

ns 

% 

Data setup to SREQ/ asserted 

55 

- 

ns 


Data hold from SACK/ asserted 

20 


ns 


SREQ/ 

SACK/ 

SD15-SD0, 
SDP1/, SDPO/ 



Figure 7-34: Target Asynchronous Receive 


Symbol 

Parameter 
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Max 

Units 

h 

SREQ/ deasserted from SACK/ asserted 

5 


ns 

h 

SREQ/ asserted from SACK/ deasserted 

5 

- 

ns 


Data setup to SACK/ asserted 

0 

- 

ns 

k 

Data hold from SREQ/ deasserted 

0 

- 

ns 


SREQ/ 

SACK/ 

SD15-SD0, 
SDP1/, SDPO/ 


\ 



:_ I 

\ ": 


t4 


Valid n 


h 

r 

I 


t2 


n+1 




Valid n+1 
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SDP1/, SDPO/ 

Figure 7-35: Initiator and Target Synchronous Transfers 


Table 7-17: SCSI-1 transfers (Single-Ended, 5.0 MB/s) 


Symbol 

Parameter 

Min 

Max 

Units 

ti 

Send SREQ/ or SACK/ assertion pulse width 

90 

- 

ns 

h 

Send SREQ/ or SACK/ deassertion pulse width 

90 

- 

ns 

h 

Receive SREQ/ or SACK/ assertion pulse width 

90 

- 

ns 

^2 

Receive SREQ/ or SACK/ deassertion pulse width 

90 

- 

ns 

h 

Send data setup to SREQ/ or SACK/ asserted 

55 

- 

ns 

t4 

Send data hold from SREQ/ or SACK/ asserted 

100 

- 

ns 

t5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

^6 

Receive data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 
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Table 7-18: SCSI-1 Transfers (Differential, 4.17 MB/s) 


Symbol 

Parameter 

Min 

Max 

Units 


Send SREQ/ or SACK/ assertion pulse width 

96 

- 

ns 

^2 

Send SREQ/ or SACK/ deassertion pulse width 

96 

- 

ns 


Receive SREQ/ or SACK/ assertion pulse width 

84 

- 

ns 

^2 

Receive SREQ/ or SACK/deassertion pulse width 

84 

- 

ns 

h 

Send data setup to SREQ/ or SACK/ asserted 

65 

- 

ns 

t4 

Send data hold from SREQ/ or SACK/ asserted 

110 

- 

ns 

t5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

^6 

Receive data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 

Table 7-19: 

SCSI-2 Fast Transfers (10.0 MB/s (8-bit transfers) or 20.0 MB/s (16-bit transfers), 40 ZVlHz clock) 

Symbol 

Parameter 

Min 

Max 

Units 

h 

Send SREQ/ or SACK/ assertion pulse width 

35 


ns 

h 

Send SREQ/ or SACK/ deassertion pulse width 

35 

- 

ns 

h 

Receive SREQ/ or SACK/ assertion pulse width 

20 

- 

ns 

h 

Receive SREQ/ or SACK/ deassertion pulse width 

20 

- 

ns 

h 

Send data setup to SREQ/ or SACK/ asserted 

33 


ns 

t4 

Send data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 

t5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

*^6 

Receive data hold from SREQ/ or SACK/ asserted 

10 

- 

ns 
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Table 7-20: SC$I-2 Fast Transfers (10.0 MB/s (8-bit transfers) or 20.0 MB/s (16-bit transfers), 50 MHz clock) 


Symbol 

Parameter 

Min 

Max 

Unit 


Send SREQ/ or SACK/ assertion pulse width 

35 

- 

ns 

^2 

Send SREQ/ or SACK/ deassertion pulse width 

35 

- 

ns 

ti 

Receive SREQ/ or SACK/ assertion pulse widdi 

20 

- 

ns 

^2 

Receive SREQ/ or SACK/ deassertion pulse width 

20 

- 

ns 

^3 

Send data setup to SREQ/ or SACK/ asserted 

33 

- 

ns 

t4 

Send data hold from SREQ/ or SACK/ asserted 

40** 

- 

ns 

t5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

% 

Receive data hold from SREQ/ or SACK/ asserted 

10 

- 

ns 


"^Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 in 
SCNTLl) is set, 

"^Analysis of system configuration is recommended due to reduced driver skew margin in differential systems 
Note: for fast SCSf set the Toler ANT Enable bit (bit 7 in STEST3), 


Table 7-21: UltraSCSI Single-Ended Transfers (20.0 MB/s (8-bit transfers) or 40.0 MBIs (16-bit transfers), 

80 MHz clock) 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Send SREQ/ or SACK/ assertion pulse width 

16 

- 

ns 

H 

Send SREQ/ or SACK/ deassertion pulse width 

16 

- 

ns 

ti 

Receive SREQ/ or SACK/ assertion pulse width 

10 

- 

ns 

H 

Receive SREQ/ or SACK/ deassertion pulse width 

10 

- 

ns 

% 

Send data setup to SREQ/ or SACK/ asserted 

12 

- 

ns 

t4 

Send data hold from SREQ/ or SACK/ asserted 

17 

- 

ns 

t5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

% 

Receive data hold from SREQ/ or SACK/ asserted 

6 

- 

ns 


"^Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 in 
SCNTLl) is set. 

Note: for fast SCSI, set the Toler ANT Enable bit (bit 7 in STEST3). During UltraSCSI transfers, the value of the Extend REQI 
ACK Filtering bit (STEST2, bit 1) has no effecLf 


7-40 


SYM53C875 Data Manual 





Electrical Characteristics 

SCSI Timings 


Table 7-22: UltraSCSI DifTerentialTransfers (20«0 2ViB/s (8-bit transfers) or 40.0 MB/s (16-bit transfers), 

SO IViHz clock) 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Send SREQ/ or SACK/ assertion pulse width 

16 

- 

ns 

t2 

Send SREQ/ or SACIC/ deassertion pulse width 

16 


ns 


Receive SREQ/ or SACK/ assertion pulse width 

10 

- 

ns 

h 

Receive SREQ/ or SACK/ deassertion pulse width 

10 

- 

ns 

t3 

Send data setup to SREQ/ or SACK/ asserted 

16 

- 

ns 


Send data hold from SREQ/ or SACK/ asserted 

21 

- 

ns 


Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

^6 

Receive data hold from SREQ/ or SACK/ asserted 

6 

- 

ns 


"^Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 in 
SCNTLl) is set. 

Note: for fast SCSf set the Toler ANT Enable bit (bit 7 in STEST3). During UltraSCSI transfers^ the value of the Extend REQI 
ACK Filtering bit (STESTZ, bit 1) has no effect.f 
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Register Summary 


SCNTLO Register R/WOOh (80h) 


7 6 ‘ 

>4 3 2 1 0 

in 

1 

aioioixioioi 

-A 

-A 

Tbit 

-S 

Tbit 

ratii 

-S 
tart 
ratii 
on f\ 

-E 

elec 

Sei 

on 

4od 

^Target Mode 

^Assert SATN/ on Parity Error 
- Reserved 
nable Parity Checking 
:t with SATN/ on a Start Sequence 
iiuence 
i^ode bit 0 
e bit 1 


SCNTL1 Register R/W 01 h (81 h) 




m 



m 


1 

n 

-E 

-A 

xtra 

n 

-D 

sse 

CIc 

-c 

isal 
rt S 
icki 

-A 

onn 

}le 1 
CSI 
dye 

1 1 ^ start SCSI Transfer 

Immediate Arbitration 

1—Assert Even SCSI Parity 
.sserl SCSI RST/ 
lected 

Halt on Parity Error or ATN Condition 

data bus 

le of Data Setup 


SCNTL2 Register R/W 02h (82h) 
7 6 5 4 3 2 1 0 


lOiOlQIOIOlQIOrO] 




L Wide SCSI Receive 
Vendor Unique Enhancement bit 0 
•—Vendor Unique Enhancement bit 0 
•-Wide SCSI Send 
SLPAR High Byte Enable 
•-SLPAR Mode 
•-Chained Mode 
•-SCSI Disconnect Unexpected 


SCNTL3 Register R/W 03h (83h) 
7 6 5 4 3 2 1 0 

iOiOiOifliOTirQ] 


i 


•— Clock Conversion Factor 
Clock Conversion Factor 
Clock Conversion Factor 
•-Enable Wide SCSI 

•— Synchronous Clock Conversion Factor bit 0 
•-Synchronous Clock Conversion Factor bit 1 
•- Synchronous Clock Conversion Factor bit 2 
•— Fast-20 Enable 


SCID Register R/W 04h (84h) 


m 


mu 


-R 

-E 

ese 

-E 

nab 

rvet 

-R 
nab 
le R 
i 

-E 

ese 
le R 
[esp 

1-Encoded Chip IDO 
•- Encoded Chip ID 1 
Encoded Chip ID 2 
needed Chip ID 3 
rved 

esponse to Selection 
onse to Reselection 


SXFER Register R/W 05h (85h) 
7 6 5 4 3 2 1 0 


S 


m 




-s 

-s 

ync 

-M 

lync 

hroi 

-N 

ax J 
hro 
nou 

^ Max SCSI Synchronous Offset 0 
*- Max SCSI Synchronous Offset 1 
^ Max SCSI Synchronous Offset 2 
lax SCSI Synchronous Offset 3 

SCSI Synchronous Offset 4 
nous Transfer Period bit 0 
s Transfer Period bit 1 


Synchronous Transfer Period bit 2 


SDID Register R/W 06h (86h) 

7 65 4 3 210 

^ Encoded Destination ID 0 
*- Encoded Destination ID 1 
Encoded Destination ID 2 
•- Encoded Destination ID 3 
•— Reserved 
•- Reserved 
Reserved 
•- Reserved 


GPREG Register R/W 07h (87h) 
7 6 5 4 3 2 1 0 

IXiXlXi&iXlxry^ 


General Purpose I/O 0 
General Purpose I/O 1 
General Purpose I/O 2 
•-General Purpose I/O 3 
General Purpose I/O 4 
•- Reserved 
•—Reserved 
•- Reserved 
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SFBR Register R/W 08h (88h) 



m 

Ffi 

Fi 


mm 

1 

-1 

-1 

B7 

-1 

B6 

n 

-1 

B5 

M- 

‘-1B2 

^1B3 

B4 


SOCL Register R/ W 09h (89h) 
7 6 5 4 3 2 1 0 


1 


Qi 






n 

-R 

-/ 

lEQ 

n 

-B 

tCK 

n 

-s 

SY 

n 

-A 

.EL 

1 ^1/0 
•-C/D 
-MSG 

TN 

1 = Active 

0 = Inactive 


SSID Register R OAh (09h) 


7 6 5 4 3 2 1 0 


E 

m 


HOT 


-s 

-R 

CSI 

Lp 

iese 

Val 

-R 

iese 

rvet 

lidE 

^ Encoded Destination SCSI ID bit 0 
Encoded Destination SCSI ID bit 1 
^ Encoded Destination SCSI ID bit 2 
*- Encoded Destination SCSI ID bit 3 
leserved 
rved 
i 

lit 


SBCL Register R OBh (8Bh) 


7 6 5 4 3 2 1 0 

ixlxlXj-xlxIidMa 


T 


t: 

C/D 


I/O 


•-MSG 

•-ATN 

^SEL 

•“BSY 

ACK 1 _ Active 

REQ 0 = Inactive 


DSTAT Register R OCh (8Ch) 
7 6 5 4 3 2 1 0 


Lcpf 


SSTATO Register R ODh (8Dh) 
7 6 5 4 3 2 1 0 




illegal Instruction Detected 
Extended Byte Parity Error Interrupt (53C875N only) 
SCRIPTS Interrupt Instruction Received 
•—Single Step Interrupt 


•-Aborted 
•- Bus Fault 

•- Master Data Parity Error 
•-DMA FIFO Empty 






SCSI Parity Signal 
SCSI Reset Signal 
•—Won Arbitration 
Lost Arbitration 
•—Arbitration In Progress 
SODL Least Significant Byte Full 
•—SODR Least Significant Byte Full 
•-SIDL Least Significant Byte Full 


SSTAT1 Register R OEh (8Eh) 
7 6 5 4 3 210 

Iflioloi&txixixra 


-snsi 


SCSI I/O signal 
SCSI C/D signal 
SCSI MSG/signal 
•—Latched SCSI Parity 
FIFO Flags bit 0 
•-FIFO Flags bit 1 
•- FIFO Flags bit 2 
•-FIFO Flags bit 3 


SSTAT2 Register R OFh (8F) 
7 6 5 4 3 2 1 0 


[mill 




L, 


L SCSI SDP1 Signal 
Last Disconnect 
•— Reserved 
•- Latched SCSI Parity 
FIFO Flags bit 4 

•-SODL Most Significant Byte Full 
•-SODR Most Significant Byte Full 
•-SIDL Most Significant Byte Full 
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Register Summary 


CTEST5 Register R/W 22h (A2h) 
7 6 5 4 3 2 1 0 


n 


JlOIOiXiXfXI 


-C 

“C 

loci 

-D 

:iocl 
k Ad 

>- ^ 
IMA 
< By 
Id re 

-D 
^ast 
FIF 
teC 
ss 1 

^ Byte Offset 8 
*- Byte Offset 9 
^ Burst Length bit 2 
iMA Direction 

;er Control for Set or Reset Pulses 
0 Size 

lounter (DBC) 
ncrementor (DNAD) 


CTEST6 Register R/W 23h {A3h) 
7 6 5 4 3 2 1 0 



m 


m 

wm 



-D 

n 

-D 

iMA 

-D 

iMA 

FIF 

iMA 
FIF 
0 b 

“ < t -Of,. 

1 2u_o^ 

1 L DMA FIFO bit 0 
■-DMA FIFO bit 1 
■-DMA FIFO bit 2 

IMA FIFO bit 3 

FIFO bit 4 

Obit 5 
it 6 


DBG Register R/W 24-26h (A4-A6) 


23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 _ 5 4 , 3 21 p 

Ixi^'I'XlXlX'l^tXtXjXiXiXiXjXiXiXiXiXiXIXiXIXIXlMI 


DCMD Register R/W 27h (A7) 
7 6 5 4 3 2 1 0 


^Function bit 0 
^ Function bit 1 
Function bit 2 
■—Function bit 3 
■—Function bit 4 
Function bit 5 

■— Instruction Op Code bit 0 
■- Instruction Op Code bit 1 


DNAD Register R/W28-2Bh (A8-ABh) 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

t om pj oi Qi oi bi om iQ lo lo Id lo lo lo lo I q\o io loiQT&ioiorgibwreTTOn 

DSP Register R/W 2C-2Fh (AC-AFh) 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

DSPS Register R/W 30-33h (B0-B3h) 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

i.X[.Xi.aMM.xi.)a:.Mxi.xj.xi.x.i.xi.xi.xr^^ 


SCRATCHA Register R/W 34-37h (B4-B7) 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 
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DMODE Register R/W38h (B8h) 


I 


1 


i 

1 




-B 

n 

-s 

lursl 

n 

-t 

our 

t Le 

-E 
lest 
ce 1 
ngt 

1 ^ Manual Start Mode 

■—Burst Op Code Fetch Enable 
— Enable Read Multiple 
inable Read Line 
ination 1/0-Memory Enable 
1/0-Memory Enable 
h bit 0 


Burst Length bit 1 


DIEN Register R/W 39h (B9h) 
7 6 5 4 3 2 1 0 


i 

m 

11 

m 

II 

II 



-R 

n 

-h 

ese 

L-b 

^ast 

rvec 

- ) 
us 1 
er L 
i 

Ls 

\bo 

Paul 

lata 

■- Illegal Instruction Detected 
■— Extended Byte Parity Error (53C875N only) 
-SCRIPTS Interrupt Instruction Received 
'ingle Step Interrupt 
rted 

It 

Parity Error 


Scratch Byte Register R/W 3Ah (BAh) 


7 6 5 4 3 2 1 0 


DCNTL Register R/W3Bh (BBh) 
7 6 5 4 3 2 1 0 


QElEiiOSliDSlO] 


I ^53C700 Compatibility Bit 
•-IRQ Disable 
*—Start DMA Operation 
■-IRQ Mode 
■—Single Step Mode 
■- Pre-fetch Enable 
■— Pre-fetch Flush 
^ Cache Line Size Enable 


ADDER Register R 3C-3Fh (BC-BFh) 


31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 




i 


SIENO Register R/W 40h (COh) 


E 

m 


IMi 


HOfSI 


-p 

-F 

'has 

-s 

unc 

eM 

- F 
;ele( 
tion 
ism 

n 

-s 

tese 

}ted 

Coi 

atci 

■—SCSI Parity Error 
■-SCSI RST/ Condition 
■-Unexpected Disconnect 
CSI Gross Error 
ilected 

mplete 

1 or SATN/Active 


SiENI Register R/W 41 h (Clh) 
7 6 5 4 3 2 1 0 

ixixrxKixraiQtoi 


I 




Handshake-to-Handshake Timer Expired 
General Purpose Timer Expired 
Selection or Reselection Time-Out 
^ Reserved 
Reserved 
Reserved 
Reserved 
•- Reserved 
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SISTO Register R 42h (C2h) 
7 6 5 4 3 2 1 0 




Parity Error Received 
SCSI RST/ received 
Unexpected Disconnect 
■-SCSI Gross Error 
*—Reselected 
•“Selected 
•— Function Complete 
Phase Mismatch or SATN/Active 


SIST1 Register R 43h (C3h) 
7 6 5 4 3 2 1 0 

iXiXiXiXiMtOitH 


j Gent 


Handshake-to-Handshake Timer Expired 
General Purpose Timer Expired 
Selection/Reselection Time-Out 
^ Reserved 
•“ Reserved 
•“ Reserved 
•“ Reserved 
Reserved 


SLPAR Register R/W 44h (C4h) 
7 6 5 4 3 2 1 0 


SWIDE Register R/W 45h (C5h) 
7 6 5 4 3 2 1 0 


r 


■ SCSI Longitudinal Parity 


SCSI Longitudinal Parity 
•“SCSI Longitudinal Parity 
•“SCSI Longitudinal Parity 
•“SCSI Longitudinal Parity 
•“SCSI Longitudinal Parity 
•“SCSI Longitudinal Parity 
•“SCSI Longitudinal Parity 


Memory Access Control Register R/W 46h (C6h) 
7 6 5 4 3 2 1 0 



IBI 

K 

IE 

IE 

mm^^m 



1 


1 

! 

SCRIPTS 

•“ Pointer SCRIPTS 
'“ Data Read 
lata Write 

1 


General Purpose Pin Control Register R/W 47h (C7h) 


E 

m 

m 

1 

1 

m 

m 



“F 

last 

•“P 
etct 
er E 

“G 
tese 
1 En 
inab 

“G 

iPIO 

rve( 

able 

lie 

1“ GPIOO Enable 
1“ GPI01 Enable 
'“GPI02 Enable 
iPI03 Enable 

14 Enable 
i 


STIMEO Register R/W 48h (C8h) 
7 6 5 4 3 2 1 0 


n 


m 


rp 



n 

“H 

“F 

lane 

n 

“H 

lane 

Isha 

“H 

land 

Isha 

ke-t 

^ Selection Time-out Period bit 0 
•“ Selection Time-out Period bit 1 
*“ Selection Time-out Period bit 2 
^ Selection Time-out Period bit 3 
andshake-to-Handshake Period bit 0 
Ishake-to-Handshake Period bit 1 
ke-to-Handshake Period bit 2 

0 -Handshake Period bit 3 


STIME1 Register R/W 49h (C9h) 


m 

[D 

1 

m 

JIM 


“R 

i 

ese 

-G 

land 

rvet 

“F 

lene 

Isha 

1 

General Purpose Timer Period bit 0 
^General Purpose Timer Period bit 1 
•“ General Purpose Timer Period bit 2 
“ General Purpose Timer Period bit 3 
landshake-to-Handshake Timer Scale Factor 
sral Purpose Timer Scale Factor 
ike-to-Handshake Timer Bus Activity Enable 
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RESPIDO Register R/W 4Ah (CAh) 


iolololj 


-II 

-II 

D7 

-II 

06 

-1 

05 

-1 

04 

1 

“I 

03 

““IDI 

02 


RESPID1 Register R/W4Bh (CBh) 



STESTO Register R/W 4Ch (CCh) 
7 6 5 4 3 2 1 0 


DDEIilKeilil 


SCSI Synchronous Offset Maximum 
^SCSI Synchronous Offset Zero 
^Arbitration Priority Encoder Test 
Selection Response Logic Test 
•“SSAIDO 
•-SSAID1 
■-SSAIDZ 
L-SSAID3 


STEST1 Register R 4Dh (CDh) 


r 

m 



mi 

5ijaxi 


-s 

n 

-s 

CLf 

n 

-R 

iCSI 

( 

-R 

iese 

Iso 

-S 

lese 

rvei 

latii 

^Reserved 
*— Reserved 
^SCLK Doubler Select 
iCLK Doubler Enable 
rved 
i 

Dn Mode 


STEST2 Register R/W 4Eh (CEh) 


7 6 5 4 3 J 

> 1 0 

[ 

HT 

o 

o 

r 

WM 


-s 

-R 

CSI 

-s 

iese 

Coi 

L-s 

0S\ 

tsc 

ntro 

-s 

CSI 

Dif 

:si i 

1 En 

I •-SCSI Low-Level Mode 
■- Extend SREQ/SACK filtering 
L-Always Wide SCSI 

CSI High Impedance Mode 
Loopback Mode 
ferential Mode 

Offset 

lable 


STEST3 Register R/W 4Fh (CFh) 
7 6 5 4 3 2 1 0 


n 



HI 


11 

H 


-T 

-s 

oler 

l-H 

CSI 

ANl 

lalt 

FIF 

rEn 

-1 

lisal 

SCS 

OTi 

labli 

1 l-SCSI FIFO Test Write 
•-Clear SCSI FIFO 

1 - Timer Test Mode 

6-bit System 

}le Single Initiator Response 

H Clock 

Bst Read 


SIDL Register R 50-51 h (D0-D1 h) 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


ixixixrxixmxixixixixixixtxDnyi 


SODL Register R/W 54-55h (D4-D5h) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


IXIXIXIXlXIXlXIXlXIXlXIXIXlXIXlXI 


SBDL Register R 58-59h (D8-D9h) 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


ixlxlxixlxixlxixixix IXIX iximn 


SCRATCHB Register R/W5C-5Fh (DC-DFh) 


31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 765 4 3 2 10 


ixixixfxrxfxixixixixixixixixixixixixixixixixixixixixixixixixixa 


SCRATCHC-J Registers R/W 60-70h (EO-FOh) 


31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


IXlXIXlXlXlXlXIXiXIXlXIXlXlXtXlXlXtXlXlXlXIXIXIXIXKIXIXIXIXKH 


31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 765 4 3 2 10 

IXlXIXlXIXIXiXIXtXIXIXIX IXIXlXIX IXIXIXIXIX IXIXlXlX lx IXIXIXIX K ■ 
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Appendix C 

External Memory Interface Diagram Examples 



MAD Bus Sense Logic Enabled for 16 KB of slow memory (200 ns Device @ 33MHz) 

Figure C-l:16 K Interface With 200 ns Memory 
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MAD Bus Sense Logic Enabled for 64 KB of fast memory (150 ns Device @ 33MHz) 


Figure C-2:64 K Interface with ISO ns Memory 
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27C020-15/ 

28F020-15/ 

Socket 


D(7-0) 
























Figure C-4:512 K Interface With 150 ns Memory 



External Memory Interface Diagram Examples 
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53C700 Compatibility bit 5-38 

A 

Abort Operation bit 5-23 
Aborted bit 5-18, 5-37 
Absolute Maximum Stress Ratings 7-1 
active negation 

see Toler ANT Technology 
active termination 2-16 
ADDER register 5-39 
Adder Sum Output register 5-39 
Additional Interface Pins 4-15 
Address and Data Pins 4-9 
Alternative Two Termination 2-17 
Alwys Wide SCSI bit 5-51 
Arbitation in Progress bit 5-20 
arbitration 

Arbitration in Progress bit 5-20 
Arbitration Mode bits 5-5 
arbitration pins 4-12 
Immediate Arbitration bit 5-8 
Lost Arbitration bit 5-20 
Won Arbitration bit 5-20 
Arbitration Mode bits 5-5 
Arbitration Priority Encoder Test bit 5-48 
Assert Even SCSI Parity bit 5-7 
Assert SATN/ on Parity Error bit 5-6 
Assert SCSI ACK/ Signal bit 5-16 
Assert SCSI ATN/ Signal bit 5-16 
Assert SCSI BSY/ Signal bit 5-16 


Assert SCSI C_D/ Signal bit 5-16 
Assert SCSI Data Bus bit 5-7 
Assert SCSI I_0 Signal bit 5-16 
Assert SCSI MSG/ Signal bit 5-16 
Assert SCSI REQ/ Signal bit 5-16 
Assert SCSI RST/ Signal bit 5-7 
Assert SCSI SEIV Signal bit 5-16 

B 

Big and Little Endian Support 2-6 
Block Move Instructions 6-4 
Burst Disable bit 5-29 
Burst Length bits 5-31, 5-35 
Burst Op Code Fetch Enable bit 5-36 
Bus Fault bit 5-18, 5-37 
Byte Empty in DMA FIFO bit 5-25 
Byte Full in DMA FIFO bit 5-25 
Byte Offset Counter bits 5-28, 5-31 

c 

Cache Line Size Enable bit 5-38 
cache mode, see PCI cache mode 3-3 
chained block moves 2-24—2-26 
SODL register 2-25 
SWIDE register 2-25 
Wide SCSI Receive Bit 2-25 
Wide SCSI Send Bit 2-24 
Chained Mode bit 5-9 
Chip Revision Level bits 5-27 
Chip Test Five register 5-30 
Chip Test Four register 5-29 
Chip Test One register 5-25 
Chip Test Six register 5-31 
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Chip Test Two register 5-26 
Chip Test Zero register 5-25 
Chip Type bits 5-44 
Clear DMA FIFO bit 5-27 
Clear SCSI FIFO bit 5-52 
Clock Address Incrementor bit 5-30 
Clock Byte Counter bit 5-30 
Clock Conversion Factor bits 5-11 
Clock Timing 7-9 
Configured as FO bit 5-26 
Configured as Memory bit 5-26 
Connected bit 5-7, 5-24 
CTESTO register 5-25 
CTESTl register 5-25 
CTEST2 register 5-26 
CTEST4 register 5-29 
CTEST5 register 5-30 
CTEST6 register 5-31 

D 

Data Acknowledge Status bit 5-26 

data path 2-11 

Data Request Status bit 5-26 

Data Structure Address register 5-22 

Data Transfer Direction bit 5-26 

DataRD bit 5-44 

DataWR bit 5-44 

DBC register 5-32 

DBLEN bit 3 5-49 

DBLSELbit2 5-49 

DCMD register 5-32 

DCNTL register 5-38 

Destination FO-Memory Enable bit 5-35 

DFIFO register 5-28 

DIEN register 5-36 

DIF bit 5-50 


differential mode 

DIFFSENS pin 4-16 
DIFFSENSE Sense bit 5-22 
direction control pins 4-14 
operation 2-13 

SCSI Differential Mode bit 5-50 
wiring diagram 2-15 
differential wiring diagram 2-15 
DIFFSENSE Sense bit 5-22 
Disable Halt on Parity Error or ATN 5-7 
Disable Single Initiator Response bit 5-52 
DAIA Byte Counter register 5-32 
DAIA Command register 5-32 
DMA Control register 5-38 
DMA core 2-1 
DMA Direction bit 5-31 
DMA FIFO bits 5-31 
DMA FIFO Empty bit 5-18 
DMA FIFO register 5-28 
DMA FIFO Size bit 5-30 
DMA Interrupt Enable register 5-36 
DAIA Interrupt Pending bit 5-24 
DMA Mode register 5-35 
DMA Next Address register 5-33 
DAIA SCRIPTS Pointer register 5-33 
DAIA SCRIPTS Pointer Save register 5-34 
DAIA Status register 5-18 
DMODE register 5-35 
DNAD register 5-33 
DSA register 5-22 
DSP register 5-33 
DSPS register 5-34 
DSTAT register 5-18 

E 

Enable Parity Checking bit 5-6 
Enable Read Line bit 5-35 
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Enable Read Multiple bit 5-35 
Enable Response to Reselection bit 5-12 
Enable Response to Selection bit 5-12 
Enable Wide SCSI bit 5-11 
Encoded Chip SCSI ID 5-12 
Encoded Destination SCSI ID bit 5-17 
Encoded Destination SCSI ID bits 5-14 
Error Reporting Pins 4-12 
Extend SREQ/SACK Filtering bit 5-51 
external memory interface 2-4 
configuration 2-5 
diagram 1-6 
flash ROM updates 2-4 
GPI04 bit 5-15 
memory sizes supported 2-4 
multiple byte accesses 7-11 
pins 4-17 
slow memory 2-5 
system requirements 2-4 
Extra Clock Cycle of Data Setup bit 5-7 

F 

Fast-20 Enable bit 5-10 
Fetch Enable 5-45 
Fetch Pin Mode bit 5-27 
FIFO Byte Control bits 5-30 
FIFO Flags bits 5-20, 5-22 
Flush DMA FIFO bit 5-27 
Fimction Complete bit 5-39, 5-41 
functional signal grouping 4-7 

G 

general description 1-1 

General Purpose Pin Control register 5-45 

General Purpose register 5-15 

General Purpose Timer Expired bit 5-40, 5-42 

General Purpose Timer Period bits 5-47 

General Purpose Timer Scale Factor bit 5-46 

GPCNTL register 5-45 


GPIO Enable bit 5-45 
GPIO4-0 bits 5-15 
GPREG register 5-15 

H 

Halt SCSI Clock bit 5-51 

Handshake to Handshake Timer Scale Factor bit 
5-47 

Handshake-to-Handshake Timer Bus Activity En¬ 
able bit 5-46 

Handshake-to-Handshake Timer Expired bit 5-40, 
5-42 

Handshake-to-Handshake Timer Period bit 5-45 
High Impedance Mode bit 5-29 

I 

FO Instructions 6-8 
Illegal Instruction Detected bit 5-18 
Immediate Arbitration bit 5-8 
instruction prefetching 2-3 
Pre-fetch Enable bit 5-38 
Pre-fetch Flush bit 5-38 
prefetch unit flushing 2-3 
instructions 

block move 6-4 
FO 6-8 

load and store 6-23 
memory move 6-20 
read/write 6-13 
transfer control 6-16 
Interface Control Pins 4-11 
internal RAM, see also SCRIPTS RAM 2-2 
Interrupt on the Fly bit 5-24 
Interrupt Output 7-10 
Interrupt Status register 5-23 
interrupts 2-21 

fatal vs. non-fatal interrupts 2-22 
halting 2-23 
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IRQ Disable bit 2-22 
masking 2-22 

sample interrupt service routine 2-24 
stacked interrupts 2-23 
IRQ Disable bit 5-38 
IRQ Mode bit 5-38 
ISTAT register 5-23 

J 

JTAG support 2-6 

L 

Last Disconnect bit 5-22 
Latched SCSI Parity bit 5-21 
Latched SCSI Parity for SD15-8 bit 5-22 
load and store instructions 6-23 
no flush option 6-23 

prefetch unit and Store instructions 2-3, 6-23 
Lost Arbitration bit 5-20 

M 

MACNTL register 5-44 

Manual Start Mode bit 5-36 

Master Control for Set or Reset Pulses bit 5-30 

Master Data Parity Error bit 5-18, 5-37 

Master Enable bit 5-45 

Master Parity Error Enable bit 5-30 

Max SCSI Synchronous Offset bits 5-14 

Memory Access Control register 5-44 

Memory Move instructions 6-20 

and SCRIPTS instruction prefetching 2-3 
No Flush option 2-3 
Memory Read Line command 3-5 
Memory Read Multiple command 3-6 
Memory Write and Invalidate command 3-4 
Write and Invalidate Mode bit 3-8 

N 

No Flush Memory Move instruction 6-21 


0 

op code fetch bursting 2-4 

Operating Conditions 7-1 

operating registers 

Adder Sum Output 5-39 

Chip Test Five 5-30 

Chip Test Four 5-29 

Chip Test One 5-25 

Chip Test Six 5-31 

Chip Test Three 5-27 

Chip Test Two 5-26 

Chip Test Zero 5-25 

Data Structure Address 5-22 

DMA B 5 rte Counter 5-32 

DMA Command 5-32 

DMA Control 5-38 

DMA HFO 5-28 

DMA Interrupt Enable 5-36 

DMA Mode 5-35 

DMA Next Address 5-33 

DMA SCRIPTS Pointer 5-33 

DMA SCRIPTS Pointer Save 5-34 

DMA Status 5-18 

general information 5-1 

General Purpose 5-15 

General Purpose Pin Control 5-45 

Interrupt Status 5-23 

Memory Access Control 5-44 

register address map 5-4 

Response ID One 5-48 

Response ID Zero 5-48 

Scratch Bj^e 5-37 

Scratch Register A 5-34 

Scratch Register B 5-54 

SCSI Bus Control Lines 5-17 

SCSI Bus Data Lines 5-54 

SCSI Chip ID 5-12 

SCSI Control One register 5-7 
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SCSI Control Register Two 5-9 
SCSI Control Three 5-10 
SCSI Control Zero 5-5 
SCSI Destination ID 5-14 
SCSI First Byte Received 5-16 
SCSI Input Data Latch 5-53 
SCSI Interrupt Enable One 5-40 
SCSI Interrupt Enable Zero 5-39 
SCSI Interrupt Status One 5-42 
SCSI Interrupt Status Zero 5-41 
SCSI Longitudinal Parity 5-43 
SCSI Output Control Latch 5-16 
SCSI Output Data Latch 5-53 
SCSI Selector ID 5-17 
SCSI Status One 5-20 
SCSI Status Two 5-21 
SCSI Status Zero 5-19 
SCSI Test One 5-49 
SCSI Test Three 5-51 
SCSI Test Two 5-50 
SCSI Test Zero 5-48 
SCSI Timer One 5-46 
SCSI Timer Zero 5-45 
SCSI Transfer 5-12 
SCSI Wide Residue 5-44 
Temporary Stack 5-28 


P 

package and feature options 1 -2 
Parity 2-7—2-9 
Parity Error bit 5-42 
PCI cache mode 3-3 

Cache Line Size Enable bit 5-38 
Cache Line Size register 3-11 
Enable Read Multiple bit 5-35 
Memory Read Line command 3-5 
Memory Read Multiple command 3-6 
Memory Write and Invalidate command 3-4 
Write and Invalidate Mode bit 3-8 
Write and Invalidate Enable bit 5-27 


PCI commands 3-1 
PCI Configuration registers 
Subsystem Data 3-12 
PCI configuration registers 3-7—3-13 
Base Address One (Memory) 3-12 
Base Address Zero (FO) 3-12 
Cache Line Size 3-11 
Class Code 3-11 
Command 3-8 
Device ID 3-8 

Expansion ROM Base Address 3-12 
Header T 5 rpe 3-12 
Interrupt Line 3-13 
Interrupt Pin 3-13 
Latency Timer 3-12 
Max_Lat 3-13 
Min_Gnt 3-13 
Revision ID 3-11 
Status 3-10 
Vendor ID 3-8 
PCI configuration space 3-1 
PCI I/O space 3-1 
PCI memory space 3-1 
PCI Timings 7-34 
Phase Mismatch bit 5-41 
pins 

additional interface pins 4-15 
address and data pins 4-9 
arbitration pins 4-12 
error reporting pins 4-12 
external memory interface pins 4-17 
functional signal grouping 4-7 
interface control pins 4-11 
SCSI pins 4-13 
system pins 4-8 
Pointer SCRIPTS bit 5-44 
Power and Ground Pins 4-5, 4-6 
Pre-fetch Enable bit 5-38 
Pre-fetch Flush bit 5-38 
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R 

RAM, see also SCRIPTS RAM 2-2 

Read/Write Instructions 6-13 

register addresses 
operating registers 
OOh 5-5 
01h5-7 
02h 5-9 
03h 5-10 
04h 5-12 
05h 5-12 
06h 5-14 
07h 5-15 
08h 5-16 
09h 5-16 
0Ah5-17 
OBh 5-17 
0Ch5-18 
ODh 5-19 
OEh 5-20 
0Fh5-21 
10-13h 5-22 
14h 5-23 
18h 5-25 
19h 5-25 
lAh 5-26 
iBh 5-27 
IC-lFh 5-28 
20h 5-28 
21h 5-29 
22h 5-30 
23h 5-31 
24-26h 5-32 
27h 5-32 
28-2Bh 5-33 
2C-2Fh 5-33 
30-33h 5-34 
34-37h 5-34 
38h 5-35 
39h 5-36 
3Ah 5-37 
3Bh 5-38 
3C-3Fh 5-39 


40h 5-39 
41h 5-40 
42h 5-41 
43h 5-42 
44h 5-43 
45h 5-44 
46h 5-44 
47h 5-45 
48h 5-45 
49h 5-46 
4Ah 5-48 
4Bh 5-48 
4Ch 5-48 
4Dh 5-49 
4Eh 5-50 
4Fh5-51 
50-5 Ih 5-53 
54-55h 5-53 
58-59h 5-54 
5C-5Fh 5-54 
60-70h 5-55 

PCI configuration registers 
OOh 3-8 
02h 3-8 
04h 3-8 
06h 3-10 
08h 3-11 
09h 3-11 
OCh 3-11 
ODh 3-12 
OEh 3-12 
lOh 3-12 
14h 3-12 
18h 3-12 
30h 3-12 
3Ch 3-13 
3Dh 3-13 
3Eh3-13 
3Fh3-13 

Subsystem Data 3-12 
register bits 

53C700 Compatibility 5-38 

Abort Operation 5-23 

Aborted 5-18, 5-37 
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Always Wide SCSI 5-51 

Arbitration in Progress 5-20 

Arbitration Mode 5-5 

Arbitration Priority Encoder Test 5-48 

Assert Even SCSI Parity (force bad parity)) 5-7 

Assert SATN/ on Parity Error 5-6 

Assert SCSI ACK/ Signal 5-16 

Assert SCSI ATN/ Signal 5-16 

Assert SCSI BSY/ Signal 5-16 

Assert SCSI C_D/ Signal 5-16 

Assert SCSI Data Bus 5-7 

Assert SCSI I_0/ Signal 5-16 

Assert SCSI MSG/ Signal 5-16 

Assert SCSI REQ/ Signal) 5-16 

Assert SCSI RST/ Signal 5-7 

Assert SCSI SEL/ Signal 5-16 

Burst Disable 5-29 

Burst Length 5-31, 5-35 

Burst Op Code Fetch Enable 5-36 

Bus Fault 5-18, 5-37 

Byte Empty in DMA FIFO 5-25 

Byte Full in DMA FIFO 5-25 

B 5 d:e Offset Counter 5-28, 5-31 

Cache Line Size Enable 5-38 

Chained Mode 5-9 

Chip Revision Level 5-27 

Chip Type 5-44 

Clear DMA HFO 5-27 

Clear SCSI FIFO 5-52 

Clock Address Incrementor 5-30 

Clock Byte Counter 5-30 

Clock Conversion Factor 5-11 

Configured as FO 5-26 

Configured as Memory 5-26 

Connected 5-7, 5-24 

Data Acknowledge Status 5-26 

Data Request Status 5-26 

Data Transfer Direction 5-26 

DataRD 5-44 


DataWR 5-44 

Destination FO-Memory Enable 5-35 

DIFFSENSE Sense 5-22 

Disable Halt on Parity Error or ATN 5-7 

Disable Single Initiator Response 5-52 

DMA Direction 5-31 

DMA FIFO 5-31 

DMA FIFO Empty 5-18 

DMA FIFO Size 5-30 

DMA Interrupt Pending 5-24 

Enable Parity Checking 5-6 

Enable Read Line 5-35 

Enable Read Multiple 5-35 

Enable Response to Reselection 5-12 

Enable Response to Selection 5-12 

Enable Wide SCSI 5-11 

Encoded Chip SCSI ID, bits 3-0 5-12 

Encoded Destination SCSI ID 5-14, 5-17 

Extend SREQ/SACK Filtering 5-51 

Extra clock cycle of data setup 5-7 

Fast-20 Enable 5-10 

Fetch Enable 5-45 

Fetch Pin Mode 5-27 

FIFO Byte Control 5-30 

FIFO Flags 5-20, 5-22 

Hush DMA FIFO 5-27 

Function Complete 5-39, 5-41 

General Purpose Timer Expired 5-40, 5-42 

General Purpose Timer Period 5-47 

General Purpose Timer Scale Factor 5-46 

GPIO Enable 5-45 

GPIO4-0 5-15 

Halt SCSI Clock 5-51 

Handshake to Handshake Timer Scale Factor 
5-47 

Handshake-to-Handshake Timer Bus Activity 
Enable 5-46 

Handshake-to-Handshake Timer Expired 5- 
40, 5-42 
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Handshake-to-Handshake Timer Period 5-45 

High Impedance Mode 5-29 

Illegal Instruction Detected 5-18 

Illegal instruction detected 5-37 

Immediate Arbitration 5-8 

Interrupt on the Fly 5-24 

IRQ Disable 5-38 

IRQ Mode 5-38 

Last Disconnect 5-22 

Latched SCSI Parity 5-21 

Latched SCSI Parity for SD15-8 5-22 

Lost Arbitration 5-20 

Manual Start Mode 5-36 

Master Control for Set or Reset Pulses 5-30 

Master Data Parity Error 5-18, 5-37 

Master Enable 5-45 

Master Parity Error Enable 5-30 

Max SCSI Synchronous Offset 5-14 

Parity Error 5-42 

Phase Mismatch 5-41 

Pointer SCRIPTS 5-44 

Pre-fetch Enable 5-38 

Pre-fetch Flush 5-38 

Reselected 5-39, 5-41 

Reset SCSI Offset 5-50 

SACK/ Status 5-17 

SATN/ Status 5-17 

SBSY/ Status 5-17 

SC_D/ Status 5-17 

SCLK 5-49 

SCLK Doubler Enable bit 5-49 
SCLK Doubler Select bit 5-49 
SCRATCHA/B Operation 5-26 
SCRIPTS 5-44 

SCRIPTS Interrupt Instruction Received 5-18 
SCRIPTS interrupt instruction received 5-37 
SCSI C_D/Signal 5-21 
SCSI Control Enable 5-50 
SCSI Data High Impedance 5-29 


SCSI Differential Mode 5-50 

SCSI Disconnect Unexpected 5-9 

SCSI FIFO Test Read 5-51 

SCSI FIFO Test Write 5-52 

SCSI Gross Error 5-40, 5-41 

SCSI High-Impedance Mode 5-51 

SCSI I_0/ Signal 5-21 

SCSI Interrupt Pending 5-24 

SCSI Isolation Mode 5-49 

SCSI Loopback Mode 5-50 

SCSI Low level Mode 5-51 

SCSI MSG/ Signal 5-21 

SCSI Parity Error 5-40 

SCSI Phase Mismatch - Initiator Mode 5-39 

SCSI Reset Condition 5-40 

SCSI RST/ Received 5-42 

SCSI RST/ Signal 5-20 

SCSI SDPO/ Parity Signal 5-20 

SCSI SDPl Signal 5-22 

SCSI Selected As ID 5-48 

SCSI Synchronous Offset Maximum 5-49 

SCSI Synchronous Offset Zero 5-49 

SCSI Synchronous Transfer Period 5-12 

SCSI True End of Process 5-26 

SCSI Valid 5-17 

Select with SATN/ on a Start Sequence 5-6 
Selected 5-39, 5-41 

Selection or Reselection Time-out 5-40, 5-42 
Selection Response Logic Test 5-48 
Selection Time-Out 5-46 
Semaphore 5-23 

Shadow Register Test Mode 5-29 
SI_0/ Status 5-17 

SIDL Least Significant Byte Full 5-19 
SIDL Most Significant Byte Full 5-21 
Signal Process 5-23, 5-26 
Single Step Interrupt 5-18 
Single-step Interrupt 5-37 
Single-step Mode 5-38 
SLPAR High Byte Enable 5-9 
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SLPARMode 5-9 

SMSG/ Status 5-17 

SODL Least Significant Byte Full 5-19 

SODL Most Significant B 5 ^e Full 5-21 

SODR Least Significant Byte Full 5-19 

SODR Most Significant Byte Full 5-21 

Software Reset 5-23 

Source FO-Memory Enable 5-35 

SREQ/ Status 5-17 

SSEL/ Status 5-17 

Start DMA Operation 5-38 

Start SCSI Transfer 5-8 

Start Sequence 5-5 

S 5 mchronous Clock Conversion Factor 5-10 
Target Mode 5-6 
Timer Test Mode 5-52 
TolerANT Enable 5-51 
Unexpected Disconnect 5-40, 5-42 
Vendor Unique Enhancements bit 0 5-9 
Vendor Unique Enhancements bit 15-10 
Wide SCSI Receive 5-10 
Wide SCSI Send 5-9 
Won Arbitration 5-20 
Write and Invalidate Enable 5-27 
Registers 

see operating registers 
Reselected bit 5-39, 5-41 
Reset Input 7-10 
Reset SCSI Offset bit 5-50 
RESPIDO register 5-48 
RESPIDl register 5-48 
Response ID One register 5-48 
Response ID Zero register 5-48 
Revision Level bits 5-27 

s 

SACK/ Status bit 5-17 
SATN/ Active 5-41 


SATN/ Active bit 5-41 

SATN/ Status bit 5-17 

SBCL register 5-17 

SBDL register 5-54 

SBR Register 5-37 

SBSY Status bit 5-17 

SC_D/ Status bit 5-17 

SCID register 5-12 

SCLK bit 5-49 

SCNTLO register 5-5 

SCNTLl register 5-7 

SCNTL2 register 5-9 

SCNTL3 register 5-10 

Scratch Register 5-37 

SCRATCHA register 5-34 

SCRATCHA/B Operation bit 5-26 

SCRATCHB register 5-54 

SCRIPTS bit 5-44 

SCRIPTS Interrupt Instruction Received bit 5-18 
SCRIPTS processor 2-1 

instruction prefetching 2-3 
internal RAM for instruction storage 2-2 
performance 2-1 
SCRIPTS RAM 2-2 

SCRATCHA/B Operation bit 5-26 
SCSI 

core 2-1 

differential mode 2-13 
pins 4-13 
termination 2-16 
timings 7-36 

TolerANT technology 1-3 
SCSI ATN Condition - Target Mode 5-39 
SCSI ATN Condition bit 5-39 
SCSI Bus Control Lines register 5-17 
SCSI Bus Data Lines register 5-54 
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SCSI bus interface 2-13—2-18 
SCSI C_D/ Signal bit 5-21 
SCSI Chip ID register 5-12 
SCSI CLK frequency 
doubling 5-50 
SCSI Clock Doubler 
using 2-3 

SCSI Control Enable bit 5-50 
SCSI Control One register 5-7 
SCSI Control Three register 5-10 
SCSI Control Two register 5-9 
SCSI Control Zero register 5-5 
SCSI core 2-1 

SCSI Data High impedance bit 5-29 
SCSI Destination ID register 5-14 
SCSI Device Management System (SDMS) 2-2 
SCSI Differential Mode bit 5-50 
SCSI Disconnect Unexpected bit 5-9 
SCSI FIFO Test Read bit 5-51 
SCSI FIFO Test Write bit 5-52 
SCSI First B 5 d;e Received register 5-16 
SCSI Gross Error bit 5-40, 5-41 
SCSI High-Impedance Mode bit 5-51 
SCSII_0/ Signal bit 5-21 
SCSI Input Data Latch register 5-53 
SCSI instructions 
block move 6-4 
FO 6-8 

load/store 6-23 
memory move 6-20 
read/write 6-13 
transfer control 6-16 
SCSI Interrupt Enable One register 5-40 
SCSI Interrupt Enable Zero register 5-39 
SCSI Interrupt Pending bit 5-24 
SCSI Interrupt Status One register 5-42 


SCSI Interrupt Status Zero register 5-41 
SCSI Isolation Mode bits 5-49 
SCSI Longitudinal Parity register 5-43 
SCSI Loopback Mode bit 5-50 
SCSI Low Level Mode bit 5-51 
SCSI MSG/ Signal bit 5-21 
SCSI Output Control Latch register 5-16 
SCSI Output Data Latch register 5-53 
SCSI Parity Error bit 5-40 
SCSI Phase Mismatch bit 5-39 
SCSI Reset Condition bit 5-40 
SCSI RST/ Received bit 5-42 
SCSI RST/ Signal bit 5-20 
SCSI SCRIPTS operation 6-1 
sample instruction 6-2 
SCSI SDPO/ Parity Signal bit 5-20 
SCSI SDPl Signal bit 5-22 
SCSI Selected As ID bits 5-48 
SCSI Selector ID register 5-17 
SCSI Status One register 5-20 
SCSI Status Two register 5-21 
SCSI Status Zero register 5-19 
SCSI S 5 mchronous Offset Maximun 5-49 
SCSI Synchronous Offset Zero bit 5-49 
SCSI Test One register 5-49 
SCSI Test Three register 5-51 
SCSI Test Two register 5-50 
SCSI Test Zero register 5-48 
SCSI Timer One register 5-46 
SCSI Timer Zero register 5-45 
SCSI timings 7-36-7-40, ??-7-40, 77-7-41 
SCSI Transfer register 5-12 
SCSI True End of Process bit 5-26 
SCSI Valid bit 5-17 
SCSI Wide Residue register 5-44 
SDID register 5-14 
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Select with SATN/ on a Start Sequence bit 5-6 
Selected bit 5-39, 5-41 

Selection or Reselection Time-out bit 5-40, 5-42 

Selection Response Logic Test bits 5-48 

Semaphore bit 5-23 

SFBR register 5-16 

Shadow Register Test Mode bit 5-29 

SI_0/ Status bit 5-17 

SIDL Least Significant B 5 ^e Full bit 5-19 

SIDL Most Significant Byte Full bit 5-21 

SIDL register 5-53 

SIENO register 5-39 

SIENl register 5-40 

SIGP bit 5-23, 5-26 

Single Step Interrupt bit 5-18 

single-ended operation 2-13 

Single-step Interrupt bit 5-37 

Single-step Mode bit 5-38 

SISTO register 5-41 

SISTl register 5-42 

SLPAR High Byte Enable 5-9 

SLPARMode bit 5-9 

SLPAR register 5-43 

SMSG/Status bit 5-17 

SOCL Least Significant B 5 ^e Full bit 5-19 

SOCL register 5-16 

SODL Most Significant Byte Full bit 5-21 
SODL register 5-53 

SODR Least Significant B 5 ^e Full bit 5-19 

SODR Most Significant B 5 ^e Full bit 5-21 

Software Reset bit 5-23 

Source FO-Memory Enable bit 5-35 

SREQ/ Status bit 5-17 

SSEL/ Status bit 5-17 

SSID register 5-17 


SSTATO register 5-19 
SSTATl register 5-20 
SSTAT2 register 5-21 
Stacked Interrupts 2-23 
Start DMA Operation bit 5-38 
Start SCSI Transfer 5-8 
Start Sequence bit 5-5 
STESTO register 5-48 
STESTl register 5-49 
STEST2 register 5-50 
STEST3 register 5-51 
STIMEO register 5-45 
STIMEl register 5-46 
SWIDE register 5-44 
SXFER register 5-12 

Synchronous Clock Conversion Factor bits 5-10 
Synchronous data transfer rates 2-18 
Synchronous Transfer Period bits 5-12 
System Pins 4-8 

T 

Target Mode bit 5-6 
TEMP register 5-28 
Temporary register 5-28 
termination 2-16 
Timer Test Mode bit 5-52 
timings 

clock 7-9 

interrupt output 7-10 
PCI 7-34 
reset input 7-10 
SCSI 7-36 

Ultra SCSI 7-40, 7-41 
TolerANT Enable bit 5-51 
TolerANT Technology 1-3 
benefits 1-3 
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electrical characteristics 7-6 Wide SCSI Send bit 5-9 

Extend SREQ/SACK Filtering bit 5-51 Won Arbitration bit 5-20 

TolerANT Enable bit 5-51 Write and Invalidate Enable bit 5-27 
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